rsnapshot is a powerful backup utility with installation options on any Linux-based machine. It can either back up a machine locally, or you can back up multiple machines, say servers for instance, from a single machine.
rsnapshot uses rsync and is written entirely in Perl with no library dependencies. No unusual requirements exist for installation. In the case of Rocky Linux, you can install rnapshot by using the EPEL repository. After the initial release of Rocky Linux 9.0, there was a time when the EPEL did not contain the rsnapshot package. That is no longer the case, but these instructions include a method of installing from source just in case this happens again.
This documentation covers the installation of rsnapshot on Rocky Linux only.
Next, install rsnapshot and some other needed tools, which are probably already installed:
sudo dnf install rsnapshot openssh-server rsync
If there are any missing dependencies, those will show up and you simply need to answer the prompt to continue. For example:
dnf install rsnapshot
Last metadata expiration check: 0:00:16 ago on Mon Feb 22 00:12:45 2021.
Dependencies resolved.
========================================================================================================================================
Package Architecture Version Repository Size
========================================================================================================================================
Installing:
rsnapshot noarch 1.4.3-1.el8 epel 121 k
Installing dependencies:
perl-Lchown x86_64 1.01-14.el8 epel 18 k
rsync x86_64 3.1.3-9.el8 baseos 404 k
Transaction Summary
========================================================================================================================================
Install 3 Packages
Total download size: 543 k
Installed size: 1.2 M
Is this ok [y/N]: y
Installing rsnapshot from source is not difficult. It does come with a downside, however, in that if there is a new version released, it would require a fresh install from source to update the version, whereas the EPEL installation method would keep you up-to-date with a simple dnf upgrade.
Installing Development Tools and Downloading the Source¶
As stated, the first step here is to install the 'Development Tools' group:
dnf groupinstall 'Development Tools'
You also need a few other packages:
dnf install wget unzip rsync openssh-server
Next you will need to download the source files from the GitHub repository. You can do this multiple ways, but the easiest in this case is probably just to download the ZIP file from the repository.
Go to https://github.com/rsnapshot/rsnapshot
Click on the Green "Code" button on the right
Right-click on the "Download ZIP" and copy the link location
Use wget or curl to download the copied link. Example:
Now that you have got everything on our machine, the next step is to build. When you unzipped the master.zip file, you ended up with an rsnapshot-master directory. You will need to change into this for our build procedure. Note that our build is using all of the package defaults, so if you want something else, you'll need to do a little investigation. Also, these steps are directly taken from the GitHub Installation page:
cd rsnapshot-master
Run the authogen.sh script to generate the configure script:
./autogen.sh
Tip
You may get several lines that look like this:
fatal: not a git repository (or any of the parent directories): .git
These are not fatal.
Next, you need to run configure with the configuration directory set:
./configure --sysconfdir=/etc
Finally, run make install:
sudo make install
During all of this, the rsnapshot.conf file will be created as rsnapshot.conf.default. You need to copy this over to rsnapshot.conf and then edit it to fit what you need on our system.
This covers copying the configuration file over. The section below on "Configuring rsnapshot" will cover the changes needed in this configuration file.
In this step, we show how to mount a drive, such as an external USB drive, used to back up your system. This particular step is only necessary if you are backing up a single machine or server, as seen in our first example.
Plugin the USB drive.
Type dmesg | grep sd which will show you the drive you want to use. In this case, it is sda1.
Example: EXT4-fs (sda1): mounting ext2 file system using the ext4 subsystem.
Unfortunately (or fortunately depending on your opinion) most modern Linux desktop operating systems automount the drive if they can. This means that, depending on various factors, rsnapshot might lose track of the drive. You want the drive to "mount" or make its files available in the same place every time.
To do that, take the drive information revealed in the dmesg command and enter mount | grep sda1, which will show this: /dev/sda1 on /media/username/8ea89e5e-9291-45c1-961d-99c346a2628a
Type sudo umount /dev/sda1 to unmount your external drive.
Next, create a mount point for the backup: sudo mkdir /mnt/backup
Mount the drive to your backup folder location: sudo mount /dev/sda1 /mnt/backup
Type mount | grep sda1 again, and you will see this: /dev/sda1 on /mnt/backup type ext2 (rw,relatime)
Next create a directory that must exist for the backup to continue on the mounted drive. You use a folder called "storage" for this example: sudo mkdir /mnt/backup/storage
Note that for a single machine, you will have to either repeat the umount and mount steps each time the drive is attached, or each time the system reboots, or automate these commands with a script.
We recommend automation. Automation is the sysadmin way.
This is the most important step. It is possible to make a mistake when making changes to the configuration file. The rsnapshot configuration requires tabs for any separation of elements, and a warning to that effect is at the top of the configuration file.
A space character will cause the entire configuration—and your backup—to fail. For instance, near the top of the configuration file is a section for the # SNAPSHOT ROOT DIRECTORY #. If you were adding this from scratch, you would type snapshot_root then TAB and then type /whatever_the_path_to_the_snapshot_root_will_be/
The best thing is that the default configuration included with rsnapshot only needs minor changes to make it work for a backup of a local machine. It is always a good idea, though, to make a backup copy of the configuration file before you start editing:
In this case, rsnapshot will run locally to back up a particular machine. In this example, we will break down the configuration file, and show you exactly what you need to change.
You will need to use vi (or edit with your favorite editor) to open the /etc/rsnapshot.conf file.
The first thing to change is the snapshot_root setting. The default has this value:
snapshot_root /.snapshots/
You need to change this to your mount point that we created above plus the addition of "storage".
snapshot_root /mnt/backup/storage/
You also want to tell the backup not to run if the drive is not mounted. To do this, remove the "#" sign (also called a remark, number sign, hash symbol, and so on.) next to no_create_root which looks this way:
no_create_root 1
Next go down to the section titled # EXTERNAL PROGRAM DEPENDENCIES # and remove the comment (again, the "#" sign) from this line:
#cmd_cp /usr/bin/cp
It now reads:
cmd_cp /usr/bin/cp
While you do not need cmd_ssh for this particular configuration, you will need it for our other option and it does not hurt to have it enabled. Find the line that says:
#cmd_ssh /usr/bin/ssh
Remove the "#" sign:
cmd_ssh /usr/bin/ssh
Next you need to skip down to the section titled # BACKUP LEVELS / INTERVALS #
Earlier versions of rsnapshot had hourly, daily, monthly, yearly but are now alpha, beta, gamma, delta. It is a bit confusing. What you need to do is add a remark to any interval that you will not use. In the configuration, delta is already remarked out.
In this example, you are not going to be running any other increments other than a nightly backup. Just add a remark to alpha and gamma. When completed, your configuration file will be:
Skip down to the logfile line, which by default is:
#logfile /var/log/rsnapshot
Remove the remark:
logfile /var/log/rsnapshot
Finally, skip down to the ### BACKUP POINTS / SCRIPTS ### section and add any directories that you want to add in the # LOCALHOST section, remember to use Tab rather than Space between elements!
For now write your changes (SHIFT :wq! for vi) and exit the configuration file.
You want to ensure that you did not add spaces or any other glaring errors to our configuration file while you were editing it. To do this, you run rsnapshot against our configuration with the configtest option:
rsnapshot configtest will show Syntax OK if no errors exist.
You should get into the habit of running configtest against a particular configuration. The reason for that will be more evident when you get into the Multiple Machine or Multiple Server Backups section.
To run configtest against a particular configuration file, run it with the -c option to specify the configuration:
With configtest verifying everything is OK, it is now time to run the backup for the first time. You can run this in test mode first if you like, so that you can see what the backup script is going to do.
Again, to do this you do not necessarily have to specify the configuration in this case, but it is a good idea to get into the habit of doing so:
rsnapshot -c /etc/rsnapshot.conf -t beta
Which will return something similar to this, showing you what will happen when the backup is actually run:
When the test meets your expectations, run it manually the first time without the test:
rsnapshot -c /etc/rsnapshot.conf beta
When the backup finishes, browse to /mnt/backup and examine the directory structure that it creates there. There will be a storage/beta.0/localhost directory, followed by the directories that you specified to backup.
Each time the backup runs, it will create another beta increment, 0-6, or 7 days worth of backups. The newest backup will always be beta.0 whereas yesterday's backup will always be beta.1.
The size of each of these backups will appear to take up the same amount (or more) of disk space, but this is because of rsnapshot's use of hard links. To restore files from yesterday's backup, you just copy them back from beta.1's directory structure.
Each backup is only an incremental backup from the previous run, BUT, because of the use of hard links, each backup directory, contains either the file or the hard-link to the file in whichever directory it was actually backed up in.
To restore files, you do not have to decide the directory or increment to restore them from, just what time stamp of the backup that you are restoring. It is a great system and uses far less disk space than many other backup solutions.
With testing completed and secure in the knowledge that things will work without issue, the next step is to set up the crontab for the root user to automate the process every day:
sudo crontab -e
If you have not run this before, choose vim.basic as your editor or your own editor preference when the Select an editor line comes up.
You are going to set your backup to automatically run at 11 PM, so you will add this to the crontab:
## Running the backup at 11 PM0023***/usr/bin/rsnapshot-c/etc/rsnapshot.confbeta`
Doing backups of multiple machines from a machine with a RAID array or large storage capacity, on-premise or from on an Internet connection elsewhere works well.
If running these backups over the Internet, you need to ensure that each location has adequate bandwidth for the backups to occur. You can use rsnapshot to synchronize an on-site server with an off-site backup array or backup server to improve data redundancy.
Running rsnapshot from a machine remotely, on-premise. Running this exact configuration is possible remotely off-premise also.
In this case, you will want to install rsnapshot on the machine that is doing all of the backups. Other assumptions are:
That the servers you will be backing up to, have a firewall rule that allows the remote machine to SSH into it
That each server that you will be backing up has a recent version of rsync installed. For Rocky Linux servers, run dnf install rsync to update your system's version of rsync.
That you have connected to the machine as the root user, or that you have run sudo -s to switch to the root user
For the server that will be running the backups, you need to generate an SSH key-pair for use during the backups. For our example, you will be creating RSA keys.
If you already have a set of keys generated, you can skip this step. You can find out by doing an ls -al .ssh and looking for an id_rsa and id_rsa.pub key pair. If none exists, use the following link to set up keys for your machine and the server(s) that you want to access:
The configuration file needs to be nearly the same as the one we created for the Basic Machine or Single Server Backup , except that you need to change some of the options.
The snapshot root is the default:
snapshot_root /.snapshots/
Comment this line out:
no_create_root 1
#no_create_root 1
The other difference here is that each machine will have its own configuration. When you get used to this, you will just copy one of your existing configuration files over to a different name and change it to fit any additional machines that you want to backup.
For now, you want to change the configuration file just (as shown above), and save it. Copy that file as a template for our first server:
cp /etc/rsnapshot.conf /etc/rsnapshot_web.conf
You want to change the configuration file and create the log and lockfile with the machine's name:
logfile /var/log/rsnapshot_web.log
lockfile /var/run/rsnapshot_web.pid
Next, you want to change rsnapshot_web.conf so that it includes the directories you want to back up. The only thing that is different here is the target.
Here is an example of the web.ourdomain.com configuration:
Assuming that everything works, you can create the configuration files for the mail server (rsnapshot_mail.conf) and portal server (rsnapshot_portal.conf), test them, and do a trial backup.
Automating backups for the multiple machine or server version is slightly different. You want to create a bash script to call the backups in order. When one finishes the next will start. This script will look similar to:
vi /usr/local/sbin/backup_all
With the content:
#!/bin/bash/# script to run rsnapshot backups in succession
/usr/bin/rsnapshot-c/etc/rsnapshot_web.confbeta
/usr/bin/rsnapshot-c/etc/rsnapshot_mail.confbeta
/usr/bin/rsnapshot-c/etc/rsnapshot_portal.confbeta
Save the script to /usr/local/sbin and make the script executable:
chmod +x /usr/local/sbin/backup_all
Create the crontab for root to run the backup script:
crontab -e
Add this line:
## Running the backup at 11 PM0023***/usr/local/sbin/backup_all
To ensure that everything is backing up according to plan, you might want to send the backup log files to your email. If you are running multiple machine backups using rsnapshot, each log file will have its own name, which you can send to your email for review by Using the postfix For Server Process Reporting procedure.
Restoring a few files or an entire backup involves copying the files you want from the directory with the date that you want to restore from back to your machine.