mirror of
https://github.com/yavook/kiwi-backup.git
synced 2024-11-22 06:53:00 +00:00
simplified build, added guards, prepared encryption
This commit is contained in:
parent
15ac0e16ba
commit
ef9fd2f93a
2 changed files with 148 additions and 55 deletions
108
Dockerfile
108
Dockerfile
|
@ -3,44 +3,6 @@ LABEL maintainer="jmm@yavook.de"
|
||||||
|
|
||||||
# Previous work: https://github.com/wernight/docker-duplicity
|
# Previous work: https://github.com/wernight/docker-duplicity
|
||||||
|
|
||||||
ENV \
|
|
||||||
#################
|
|
||||||
# BACKUP POLICY #
|
|
||||||
#################
|
|
||||||
#
|
|
||||||
# when to run backups
|
|
||||||
# default: "36 03 * * * " <=> daily at 3:36 am
|
|
||||||
SCHEDULE_BACKUP="36 03 * * * " \
|
|
||||||
#
|
|
||||||
# when to remove failed transactions
|
|
||||||
# default: "36 04 * * * " <=> daily at 04:36 am
|
|
||||||
SCHEDULE_CLEANUP="36 04 * * * " \
|
|
||||||
#
|
|
||||||
# how often to opt for a full backup
|
|
||||||
# default: 4M <=> every 4 months
|
|
||||||
FULL_BACKUP_FREQUENCY=4M \
|
|
||||||
#
|
|
||||||
# how long to keep backups at all
|
|
||||||
# default: 9M <=> 9 months
|
|
||||||
BACKUP_RETENTION_TIME=9M \
|
|
||||||
#
|
|
||||||
# how many full backup chains with incrementals to keep
|
|
||||||
# default: 1
|
|
||||||
KEEP_NUM_FULL_CHAINS=1 \
|
|
||||||
\
|
|
||||||
##################
|
|
||||||
# CRON SCHEDULES #
|
|
||||||
##################
|
|
||||||
#
|
|
||||||
# when to remove old full backup chains
|
|
||||||
# default: "36 05 * * SAT" <=> every saturday at 05:36 am
|
|
||||||
SCHEDULE_RMFULL="36 05 * * SAT" \
|
|
||||||
#
|
|
||||||
# when to remove old incremental backups
|
|
||||||
# default: "36 05 * * SUN" <=> every sunday at 05:36 am
|
|
||||||
SCHEDULE_RMINCR="36 05 * * SUN"
|
|
||||||
|
|
||||||
|
|
||||||
RUN set -ex; \
|
RUN set -ex; \
|
||||||
\
|
\
|
||||||
apk add --no-cache \
|
apk add --no-cache \
|
||||||
|
@ -112,8 +74,74 @@ RUN set -ex; \
|
||||||
pip3 uninstall -y wheel; \
|
pip3 uninstall -y wheel; \
|
||||||
apk del --purge .build-deps
|
apk del --purge .build-deps
|
||||||
|
|
||||||
|
VOLUME ["/backup/source", "/root/.cache/duplicity"]
|
||||||
|
|
||||||
|
ENV \
|
||||||
|
#################
|
||||||
|
# BACKUP POLICY #
|
||||||
|
#################
|
||||||
|
#
|
||||||
|
# when to run backups
|
||||||
|
# default: "36 03 * * *" <=> daily at 3:36 am
|
||||||
|
SCHEDULE_BACKUP="36 03 * * *" \
|
||||||
|
#
|
||||||
|
# when to remove failed transactions
|
||||||
|
# default: "36 04 * * *" <=> daily at 04:36 am
|
||||||
|
SCHEDULE_CLEANUP="36 04 * * *" \
|
||||||
|
#
|
||||||
|
# how often to opt for a full backup
|
||||||
|
# default: 4M <=> every 4 months
|
||||||
|
FULL_BACKUP_FREQUENCY=4M \
|
||||||
|
#
|
||||||
|
# how long to keep backups at all
|
||||||
|
# default: 9M <=> 9 months
|
||||||
|
BACKUP_RETENTION_TIME=9M \
|
||||||
|
#
|
||||||
|
# how many full backup chains with incrementals to keep
|
||||||
|
# default: 1
|
||||||
|
KEEP_NUM_FULL_CHAINS=1 \
|
||||||
|
#
|
||||||
|
# where to put backups
|
||||||
|
# default: "file:///backup/target" <=> in a host-mounted volume
|
||||||
|
BACKUP_TARGET="file:///backup/target" \
|
||||||
|
\
|
||||||
|
##############
|
||||||
|
# ENCRYPTION #
|
||||||
|
##############
|
||||||
|
#
|
||||||
|
# GnuPG key-id as specified by https://www.gnupg.org/documentation/manpage.html#sec-2-6
|
||||||
|
GPG_KEY_ID="" \
|
||||||
|
#
|
||||||
|
GPG_PASSPHRASE="" \
|
||||||
|
\
|
||||||
|
######################
|
||||||
|
# ADDITIONAL OPTIONS #
|
||||||
|
######################
|
||||||
|
#
|
||||||
|
# when to remove old full backup chains
|
||||||
|
# default: "36 05 * * SAT" <=> every saturday at 05:36 am
|
||||||
|
SCHEDULE_RMFULL="36 05 * * SAT" \
|
||||||
|
#
|
||||||
|
# when to remove old incremental backups
|
||||||
|
# default: "36 05 * * SUN" <=> every sunday at 05:36 am
|
||||||
|
SCHEDULE_RMINCR="36 05 * * SUN" \
|
||||||
|
#
|
||||||
|
# size of individual duplicity data volumes
|
||||||
|
# default: 1024 <=> 1GiB
|
||||||
|
BACKUP_VOLSIZE=1024 \
|
||||||
|
#
|
||||||
|
# Additional options for "duplicity" command
|
||||||
|
OPTIONS_BACKUP="" \
|
||||||
|
#
|
||||||
|
# Additional options for "duplicity cleanup" command
|
||||||
|
OPTIONS_CLEANUP="" \
|
||||||
|
#
|
||||||
|
# Additional options for "duplicity remove-older-than" command
|
||||||
|
OPTIONS_RMFULL="" \
|
||||||
|
#
|
||||||
|
# Additional options for "duplicity remove-all-inc-of-but-n-full" command
|
||||||
|
OPTIONS_RMINCR=""
|
||||||
|
|
||||||
COPY run.sh /usr/local/bin/do-plicity
|
COPY run.sh /usr/local/bin/do-plicity
|
||||||
|
|
||||||
VOLUME ["/backup/source", "/backup/target", "/root/.cache/duplicity", "/root/.gnupg"]
|
|
||||||
|
|
||||||
CMD ["do-plicity"]
|
CMD ["do-plicity"]
|
||||||
|
|
95
run.sh
95
run.sh
|
@ -1,47 +1,112 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
|
|
||||||
get_cron_line() {
|
#############
|
||||||
|
# CONSTANTS #
|
||||||
|
#############
|
||||||
|
|
||||||
|
env_exe="$(command -v env)"
|
||||||
|
ionice_exe="$(command -v ionice)"
|
||||||
|
duplicity_exe="$(command -v duplicity)"
|
||||||
|
|
||||||
|
if [ -n "${GPG_KEY_ID}" ]; then
|
||||||
|
# gpg key given
|
||||||
|
env_changes="PASSPHRASE='${GPG_PASSPHRASE}'"
|
||||||
|
encrypt_opts="--encrypt-key='${GPG_KEY_ID}'"
|
||||||
|
else
|
||||||
|
# no key given
|
||||||
|
env_changes=""
|
||||||
|
encrypt_opts="--no-encryption"
|
||||||
|
fi
|
||||||
|
|
||||||
|
#############
|
||||||
|
# FUNCTIONS #
|
||||||
|
#############
|
||||||
|
|
||||||
|
trim_options() {
|
||||||
|
# if args are given, trim whitespace, then add a space in front
|
||||||
|
if [ -n "${1}" ]; then
|
||||||
|
echo " $( echo "${1}" | xargs )"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
print_command() {
|
||||||
task="${1}"
|
task="${1}"
|
||||||
shift 1
|
shift 1
|
||||||
|
|
||||||
cmdline='/bin/ionice -c 3 /usr/bin/duplicity --no-encryption'
|
if [ -n "${env_changes}" ]; then
|
||||||
|
# should change environment
|
||||||
|
cmdline="${env_exe} ${env_changes} "
|
||||||
|
else
|
||||||
|
cmdline=""
|
||||||
|
fi
|
||||||
|
|
||||||
|
cmdline="${cmdline}${ionice_exe} -c 3 ${duplicity_exe} ${encrypt_opts}"
|
||||||
|
|
||||||
case "${task}" in
|
case "${task}" in
|
||||||
backup)
|
backup)
|
||||||
cmdline="${cmdline} --allow-source-mismatch --volsize 1024 --full-if-older-than ${FULL_BACKUP_FREQUENCY} /backup/source"
|
cmdline="${cmdline} --allow-source-mismatch --volsize '${BACKUP_VOLSIZE}' --full-if-older-than '${FULL_BACKUP_FREQUENCY}'"
|
||||||
|
cmdline="${cmdline}$( trim_options "${OPTIONS_BACKUP}" )"
|
||||||
|
cmdline="${cmdline} /backup/source"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
clean)
|
cleanup)
|
||||||
cmdline="${cmdline} cleanup --force"
|
cmdline="${cmdline} cleanup --force"
|
||||||
|
cmdline="${cmdline}$( trim_options "${OPTIONS_CLEAN}" )"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
rmfull)
|
rmfull)
|
||||||
cmdline="${cmdline} remove-older-than ${BACKUP_RETENTION_TIME} --force"
|
cmdline="${cmdline} remove-older-than '${BACKUP_RETENTION_TIME}' --force"
|
||||||
|
cmdline="${cmdline}$( trim_options "${OPTIONS_RMFULL}" )"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
rmincr)
|
rmincr)
|
||||||
cmdline="${cmdline} remove-all-inc-of-but-n-full ${KEEP_NUM_FULL_CHAINS} --force"
|
cmdline="${cmdline} remove-all-inc-of-but-n-full '${KEEP_NUM_FULL_CHAINS}' --force"
|
||||||
|
cmdline="${cmdline}$( trim_options "${OPTIONS_RMINCR}" )"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
cmdline="${cmdline} file:///backup/target"
|
cmdline="${cmdline} '${BACKUP_TARGET}'"
|
||||||
echo "${cmdline}"
|
echo "${cmdline}"
|
||||||
}
|
}
|
||||||
|
|
||||||
prepare_crontab() {
|
print_cron_schedule() {
|
||||||
echo "${SCHEDULE_BACKUP}" "$(get_cron_line backup)"
|
min="$( echo "${1}" | cut -d' ' -f1 )"
|
||||||
echo "${SCHEDULE_CLEANUP}" "$(get_cron_line clean)"
|
hour="$( echo "${1}" | cut -d' ' -f2 )"
|
||||||
echo "${SCHEDULE_RMFULL}" "$(get_cron_line rmfull)"
|
day="$( echo "${1}" | cut -d' ' -f3 )"
|
||||||
echo "${SCHEDULE_RMINCR}" "$(get_cron_line rmincr)"
|
month="$( echo "${1}" | cut -d' ' -f4 )"
|
||||||
|
weekday="$( echo "${1}" | cut -d' ' -f5 )"
|
||||||
|
command="${2}"
|
||||||
|
|
||||||
|
printf '%-8s%-8s%-8s%-8s%-8s%s' "${min}" "${hour}" "${day}" "${month}" "${weekday}" "${command}"
|
||||||
}
|
}
|
||||||
|
|
||||||
get_crontab() {
|
print_cron_header() {
|
||||||
|
# don't split the '#' from 'min'
|
||||||
|
print_cron_schedule '#_min hour day month weekday' 'command' | tr '_' ' '
|
||||||
|
}
|
||||||
|
|
||||||
|
print_crontab() {
|
||||||
echo '# crontab generated for kiwi-backup'
|
echo '# crontab generated for kiwi-backup'
|
||||||
printf '# generation time: '; date
|
printf '# generation time: '; date
|
||||||
echo '#'
|
echo '#'
|
||||||
prepare_crontab
|
echo "$( print_cron_header )"
|
||||||
|
echo "$( print_cron_schedule "${SCHEDULE_BACKUP}" "$( print_command backup )" )"
|
||||||
|
echo "$( print_cron_schedule "${SCHEDULE_CLEANUP}" "$( print_command cleanup )" )"
|
||||||
|
echo "$( print_cron_schedule "${SCHEDULE_RMFULL}" "$( print_command rmfull )" )"
|
||||||
|
echo "$( print_cron_schedule "${SCHEDULE_RMINCR}" "$( print_command rmincr )" )"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
########
|
||||||
|
# MAIN #
|
||||||
|
########
|
||||||
|
|
||||||
|
if [ "${1}" = '-n' ]; then
|
||||||
|
# dry-run
|
||||||
|
print_crontab
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
# replace crontab, start crond
|
# replace crontab, start crond
|
||||||
get_crontab | crontab -
|
print_crontab | crontab -
|
||||||
crond -fl 8
|
crond -fl 8
|
||||||
|
exit 0
|
||||||
|
|
Loading…
Reference in a new issue