Added a new configuration option, BACKUP_INTERVAL
This commit is contained in:
parent
1a27402970
commit
ade7679b1e
19
README.md
19
README.md
|
@ -1,13 +1,16 @@
|
|||
docker-s3-volume
|
||||
==============
|
||||
# docker-s3-volume
|
||||
|
||||
Creates a Docker container that is restored and backed up to a directory on s3. You could use this to run short lived processes that work with and persist data to and from S3.
|
||||
Creates a Docker container that is restored and backed up to a directory on s3.
|
||||
You could use this to run short lived processes that work with and persist data to and from S3.
|
||||
|
||||
Usage:
|
||||
|
||||
```
|
||||
docker run -it --rm \
|
||||
-e ACCESS_KEY=... -e SECRET_KEY=... whatupdave/s3-volume s3://<BUCKET>/<PATH>
|
||||
```
|
||||
docker run -it --rm \
|
||||
-e AWS_ACCESS_KEY_ID=... -e AWS_SECRET_ACCESS_KEY=... -e BACKUP_INTERVAL=... \
|
||||
whatupdave/s3-volume s3://<BUCKET>/<PATH>
|
||||
|
||||
This pulls down the contents of a directory on S3. If the container is stopped or sent a `USR1` signal, it will backup the modified local contents to S3.
|
||||
This pulls down the contents of a directory on S3. If the container is stopped or sent a `USR1` signal,
|
||||
it will backup the modified local contents to S3.
|
||||
|
||||
If you supply a `BACKUP_INTERVAL` environment variable, a backup will be issued each interval. The value can
|
||||
be specified in seconds, minutes, hours or days (adding `s`, `m`, `h` or `d` as suffix).
|
||||
|
|
25
watch
25
watch
|
@ -3,32 +3,30 @@
|
|||
[[ "$TRACE" ]] && set -x
|
||||
|
||||
function usage {
|
||||
cat <<-EOF
|
||||
cat <<-EOF
|
||||
Usage: $PROGNAME [OPTIONS] <local-path> <remote-path>
|
||||
Sync s3 directory locally and backup changed files on exit
|
||||
|
||||
--force-restore restore even if local directory is not empty
|
||||
|
||||
eg: $PROGNAME /data s3://bucket/dir
|
||||
EOF
|
||||
EOF
|
||||
}
|
||||
|
||||
function error_exit {
|
||||
echo "${1:-"Unknown Error"}" 1>&2
|
||||
exit 1
|
||||
echo "${1:-"Unknown Error"}" 1>&2
|
||||
exit 1
|
||||
}
|
||||
|
||||
PARSED_OPTIONS=$(getopt -n "$0" -o f --long "force-restore" -- "$@")
|
||||
if [ $? -ne 0 ];
|
||||
then
|
||||
if [ $? -ne 0 ]; then
|
||||
exit 1
|
||||
fi
|
||||
eval set -- "$PARSED_OPTIONS"
|
||||
|
||||
while true;
|
||||
do
|
||||
while true; do
|
||||
case "$1" in
|
||||
-f|--force-restore)
|
||||
-f|--force-restore)
|
||||
FORCE_RESTORE="true"
|
||||
shift;;
|
||||
|
||||
|
@ -44,9 +42,9 @@ REMOTE=$2
|
|||
|
||||
function restore {
|
||||
if [ "$(ls -A $LOCAL)" ]; then
|
||||
if [[ ${FORCE_RESTORE:false} == 'true' ]]; then
|
||||
error_exit "local directory is not empty"
|
||||
fi
|
||||
if [[ ${FORCE_RESTORE:false} == 'true' ]]; then
|
||||
error_exit "local directory is not empty"
|
||||
fi
|
||||
fi
|
||||
|
||||
echo "restoring $REMOTE => $LOCAL"
|
||||
|
@ -75,8 +73,9 @@ function final_backup {
|
|||
function idle {
|
||||
echo "ready"
|
||||
while true; do
|
||||
sleep 42 &
|
||||
sleep ${BACKUP_INTERVAL:-42} &
|
||||
wait $!
|
||||
[ -n "$BACKUP_INTERVAL" ] && backup
|
||||
done
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue