From 7d8586a8ebfdfce3db88052ef16aee3fa8533648 Mon Sep 17 00:00:00 2001 From: cryobry <38270216+cryobry@users.noreply.github.com> Date: Wed, 8 Apr 2020 10:39:35 -0400 Subject: [PATCH] Add files --- rsnapshot-daily.timer | 10 ++ rsnapshot-home-excludes.txt | 21 +++ rsnapshot-hourly.timer | 10 ++ rsnapshot-monthly.timer | 10 ++ rsnapshot-schedule.target | 5 + rsnapshot-weekly.timer | 10 ++ rsnapshot.conf | 252 ++++++++++++++++++++++++++++++++++++ rsnapshot@.service | 15 +++ 8 files changed, 333 insertions(+) create mode 100644 rsnapshot-daily.timer create mode 100644 rsnapshot-home-excludes.txt create mode 100644 rsnapshot-hourly.timer create mode 100644 rsnapshot-monthly.timer create mode 100644 rsnapshot-schedule.target create mode 100644 rsnapshot-weekly.timer create mode 100644 rsnapshot.conf create mode 100644 rsnapshot@.service diff --git a/rsnapshot-daily.timer b/rsnapshot-daily.timer new file mode 100644 index 0000000..ae0302e --- /dev/null +++ b/rsnapshot-daily.timer @@ -0,0 +1,10 @@ +[Unit] +Description=rsnapshot daily backup +PartOf=rsnapshot-schedule.target + +[Timer] +# 05:30 is the clock time when to start it +OnCalendar=05:30 +Persistent=true +Unit=rsnapshot@daily.service + diff --git a/rsnapshot-home-excludes.txt b/rsnapshot-home-excludes.txt new file mode 100644 index 0000000..cd0c7d2 --- /dev/null +++ b/rsnapshot-home-excludes.txt @@ -0,0 +1,21 @@ +Documents/ +Music/ +Podcasts/ +MD/ +Pictures/ +Public/ +Templates/ +Trash/ +Videos/ +Downloads/ +E-Books/ +Games/ +scratch/ +go/pkg/ +.music_cache/ +.Trash-1000/ +.local/share/containers/storage +.cache/ +.ccache/ +.config/syncthing/index*.db/ +.mozilla/ diff --git a/rsnapshot-hourly.timer b/rsnapshot-hourly.timer new file mode 100644 index 0000000..5e823a2 --- /dev/null +++ b/rsnapshot-hourly.timer @@ -0,0 +1,10 @@ +[Unit] +Description=rsnapshot hourly backup +PartOf=rsnapshot-schedule.target + +[Timer] +# Run hourly +OnCalendar=*-*-* *:00:00 +Persistent=true +Unit=rsnapshot@hourly.service + diff --git a/rsnapshot-monthly.timer b/rsnapshot-monthly.timer new file mode 100644 index 0000000..82838e1 --- /dev/null +++ b/rsnapshot-monthly.timer @@ -0,0 +1,10 @@ +[Unit] +Description=rsnapshot monthly backup +PartOf=rsnapshot-schedule.target + +[Timer] +# Run once per month at 3:30 UTC, after daily and weekly runs +OnCalendar=*-*-1 03:30:00 +Persistent=true +Unit=rsnapshot@monthly.service + diff --git a/rsnapshot-schedule.target b/rsnapshot-schedule.target new file mode 100644 index 0000000..344084e --- /dev/null +++ b/rsnapshot-schedule.target @@ -0,0 +1,5 @@ +[Unit] +Description=rsnapshot scheduled backup +Wants=rsnapshot-hourly.timer rsnapshot-daily.timer rsnapshot-weekly.timer rsnapshot-monthly.timer +After=default.target +Requires=run-media-bryan-sd\x2dhomebackup.mount diff --git a/rsnapshot-weekly.timer b/rsnapshot-weekly.timer new file mode 100644 index 0000000..b509cff --- /dev/null +++ b/rsnapshot-weekly.timer @@ -0,0 +1,10 @@ +[Unit] +Description=rsnapshot weekly backup +PartOf=rsnapshot-schedule.target + +[Timer] +# Run once per week on Monday at 4:30, after daily runs +OnCalendar=Monday *-*-* 04:30:00 +Persistent=true +Unit=rsnapshot@weekly.service + diff --git a/rsnapshot.conf b/rsnapshot.conf new file mode 100644 index 0000000..b89289c --- /dev/null +++ b/rsnapshot.conf @@ -0,0 +1,252 @@ +################################################# +# rsnapshot.conf - rsnapshot configuration file # +################################################# +# # +# PLEASE BE AWARE OF THE FOLLOWING RULE: # +# # +# This file requires tabs between elements # +# # +################################################# + +####################### +# CONFIG FILE VERSION # +####################### + +config_version 1.2 + +########################### +# SNAPSHOT ROOT DIRECTORY # +########################### + +# All snapshots will be stored under this root directory. +# +snapshot_root /run/media/bryan/sd-homebackup/ + +# If no_create_root is enabled, rsnapshot will not automatically create the +# snapshot_root directory. This is particularly useful if you are backing +# up to removable media, such as a FireWire or USB drive. +# +no_create_root 1 + +################################# +# EXTERNAL PROGRAM DEPENDENCIES # +################################# + +# LINUX USERS: Be sure to uncomment "cmd_cp". This gives you extra features. +# EVERYONE ELSE: Leave "cmd_cp" commented out for compatibility. +# +# See the README file or the man page for more details. +# +cmd_cp /usr/bin/cp + +# uncomment this to use the rm program instead of the built-in perl routine. +# +cmd_rm /usr/bin/rm + +# rsync must be enabled for anything to work. This is the only command that +# must be enabled. +# +cmd_rsync /usr/bin/rsync + +# Uncomment this to enable remote ssh backups over rsync. +# +cmd_ssh /usr/bin/ssh + +# Comment this out to disable syslog support. +# +cmd_logger /usr/bin/logger + +# Uncomment this to specify the path to "du" for disk usage checks. +# If you have an older version of "du", you may also want to check the +# "du_args" parameter below. +# +cmd_du /usr/bin/du + +# Uncomment this to specify the path to rsnapshot-diff. +# +#cmd_rsnapshot_diff /usr/local/bin/rsnapshot-diff + +# Specify the path to a script (and any optional arguments) to run right +# before rsnapshot syncs files +# +#cmd_preexec /path/to/preexec/script + +# Specify the path to a script (and any optional arguments) to run right +# after rsnapshot syncs files +# +#cmd_postexec /path/to/postexec/script + +# Paths to lvcreate, lvremove, mount and umount commands, for use with +# Linux LVMs. +# +#linux_lvm_cmd_lvcreate /usr/sbin/lvcreate +#linux_lvm_cmd_lvremove /usr/sbin/lvremove +#linux_lvm_cmd_mount /usr/bin/mount +#linux_lvm_cmd_umount /usr/bin/umount + +######################################### +# BACKUP LEVELS / INTERVALS # +# Must be unique and in ascending order # +# e.g. alpha, beta, gamma, etc. # +######################################### + +#retain start 2 +retain hourly 24 +retain daily 7 +retain weekly 4 +retain monthly 6 + +############################################ +# GLOBAL OPTIONS # +# All are optional, with sensible defaults # +############################################ + +# Verbose level, 1 through 5. +# 1 Quiet Print fatal errors only +# 2 Default Print errors and warnings only +# 3 Verbose Show equivalent shell commands being executed +# 4 Extra Verbose Show extra verbose information +# 5 Debug mode Everything +# +verbose 1 + +# Same as "verbose" above, but controls the amount of data sent to the +# logfile, if one is being used. The default is 3. +# +loglevel 3 + +# If you enable this, data will be written to the file you specify. The +# amount of data written is controlled by the "loglevel" parameter. +# +#logfile /var/log/rsnapshot + +# If enabled, rsnapshot will write a lockfile to prevent two instances +# from running simultaneously (and messing up the snapshot_root). +# If you enable this, make sure the lockfile directory is not world +# writable. Otherwise anyone can prevent the program from running. +# +lockfile /home/bryan/.config/systemd/user/rsnapshot.pid + +# By default, rsnapshot check lockfile, check if PID is running +# and if not, consider lockfile as stale, then start +# Enabling this stop rsnapshot if PID in lockfile is not running +# +#stop_on_stale_lockfile 0 + +# Default rsync args. All rsync commands have at least these options set. +# +rsync_short_args -aAX +rsync_long_args --delete +#rsync_long_args --delete --numeric-ids --relative --delete-excluded + +# ssh has no args passed by default, but you can specify some here. +# +#ssh_args -p 22 + +# Default arguments for the "du" program (for disk space reporting). +# The GNU version of "du" is preferred. See the man page for more details. +# If your version of "du" doesn't support the -h flag, try -k flag instead. +# +#du_args -csh + +# If this is enabled, rsync won't span filesystem partitions within a +# backup point. This essentially passes the -x option to rsync. +# The default is 0 (off). +# +#one_fs 0 + +# The include and exclude parameters, if enabled, simply get passed directly +# to rsync. If you have multiple include/exclude patterns, put each one on a +# separate line. Please look up the --include and --exclude options in the +# rsync man page for more details on how to specify file name patterns. +# +#include ??? +#include ??? +#exclude ??? +#exclude ??? + +# The include_file and exclude_file parameters, if enabled, simply get +# passed directly to rsync. Please look up the --include-from and +# --exclude-from options in the rsync man page for more details. +# +#include_file /path/to/include/file +exclude_file /home/bryan/.config/systemd/user/rsnapshot-home-excludes.txt + +# If your version of rsync supports --link-dest, consider enabling this. +# This is the best way to support special files (FIFOs, etc) cross-platform. +# The default is 0 (off). +# +#link_dest 0 + +# When sync_first is enabled, it changes the default behaviour of rsnapshot. +# Normally, when rsnapshot is called with its lowest interval +# (i.e.: "rsnapshot alpha"), it will sync files AND rotate the lowest +# intervals. With sync_first enabled, "rsnapshot sync" handles the file sync, +# and all interval calls simply rotate files. See the man page for more +# details. The default is 0 (off). +# +#sync_first 0 + +# If enabled, rsnapshot will move the oldest directory for each interval +# to [interval_name].delete, then it will remove the lockfile and delete +# that directory just before it exits. The default is 0 (off). +# +#use_lazy_deletes 0 + +# Number of rsync re-tries. If you experience any network problems or +# network card issues that tend to cause ssh to fail with errors like +# "Corrupted MAC on input", for example, set this to a non-zero value +# to have the rsync operation re-tried. +# +#rsync_numtries 0 + +# LVM parameters. Used to backup with creating lvm snapshot before backup +# and removing it after. This should ensure consistency of data in some special +# cases +# +# LVM snapshot(s) size (lvcreate --size option). +# +#linux_lvm_snapshotsize 100M + +# Name to be used when creating the LVM logical volume snapshot(s). +# +#linux_lvm_snapshotname rsnapshot + +# Path to the LVM Volume Groups. +# +#linux_lvm_vgpath /dev + +# Mount point to use to temporarily mount the snapshot(s). +# +#linux_lvm_mountpath /path/to/mount/lvm/snapshot/during/backup + +############################### +### BACKUP POINTS / SCRIPTS ### +############################### + +# LOCALHOST +backup /home/bryan/ localhost/ +#backup /etc/ localhost/ +#backup /usr/local/ localhost/ +#backup /var/log/rsnapshot localhost/ +#backup /etc/passwd localhost/ +#backup /home/foo/My Documents/ localhost/ +#backup /foo/bar/ localhost/ one_fs=1, rsync_short_args=-urltvpog +#backup_script /usr/local/bin/backup_pgsql.sh localhost/postgres/ +# You must set linux_lvm_* parameters below before using lvm snapshots +#backup lvm://vg0/xen-home/ lvm-vg0/xen-home/ + +# EXAMPLE.COM +#backup_exec /bin/date "+ backup of example.com started at %c" +#backup root@example.com:/home/ example.com/ +rsync_long_args=--bwlimit=16,exclude=core +#backup root@example.com:/etc/ example.com/ exclude=mtab,exclude=core +#backup_exec ssh root@example.com "mysqldump -A > /var/db/dump/mysql.sql" +#backup root@example.com:/var/db/dump/ example.com/ +#backup_exec /bin/date "+ backup of example.com ended at %c" + +# CVS.SOURCEFORGE.NET +#backup_script /usr/local/bin/backup_rsnapshot_cvsroot.sh rsnapshot.cvs.sourceforge.net/ + +# RSYNC.SAMBA.ORG +#backup rsync://rsync.samba.org/rsyncftp/ rsync.samba.org/rsyncftp/ + diff --git a/rsnapshot@.service b/rsnapshot@.service new file mode 100644 index 0000000..7761edb --- /dev/null +++ b/rsnapshot@.service @@ -0,0 +1,15 @@ +[Unit] +Description=rsnapshot (%I) backup +After=run-media-bryan-sd\x2dhomebackup.mount +Requires=run-media-bryan-sd\x2dhomebackup.mount +ConditionACPower=true + +[Service] +Type=oneshot +Nice=19 +IOSchedulingClass=idle +PIDFile=%h/.config/systemd/user/rsnapshot.pid +ExecStart=/usr/bin/rsnapshot -c %h/.config/systemd/user/rsnapshot.conf %I + + +