BackupPC FAQ: Backing up the localhost (BackupPC server)
- Why backup the local host using BackupPC?
- How do you setup the local host to backup?
Why backup the local host using BackupPC?
If you have multiple disks, some reserved for BackupPC, thenit makes sense to backup the remaining disks to BackupPC.
Even if you haven't installed dedicated disks for BackupPC's data,backing up the non-BackupPC parts of your file systems providesprotection from inadvertently deleted data.
Back to Top
How do you setup the local host to backup?
The three issues are:
- Don't backup the BackupPC data directory! This recursion willsteadily fill up your disk. Make sure you set $Conf,$Conf or $Conf so that theBackupPC data directory is not backed up.
- Decide on the $Conf, most likely tar, rsync or rsyncd.
In some case, although not likely, you might need to set$Conf to 'localhost' if the XferMethod can'tcontact the host by regular host name.
- If you want to use tar or rsync, you will need to run these programsas root (user id 0). This elevation of user privileges can be donewill ``ssh HOST -l root'' like any other client. But then ssh willneedlessly encrypt all the.network traffic, which is not necessaryin this case.
Daniel Poelzleithner suggests the alternative of using sudo, so there isno overhead with ssh. For example:
$Conf = '/usr/bin/sudo $tarPath -c -v -f - -C $shareName+ --totals';
Then run visudo to give BackupPC permission to run sudo without apassword, but only be able to run the /bin/tar command. For example,add this line:
backuppc ALL = NOPASSWD: /bin/tar
Note that an attacker who can become the backuppc user can thenuse sudo to run /bin/tar as root. Importantly, this means they canwrite files anywhere on the file system by doing tar -x. Thisallows them to become root.
If you want to be more cautious, you could create a short shell script(eg: tarCreate) that includes the create argument arguments from$Conf, eg:
#!/bin/sh -f
exec /bin/tar -c $*Make sure this script and all parent directories have no writepermission. Then remove the -c from $Conf and changethe tar path:
$Conf = '/usr/bin/sudo /path/to/tarCreate -v -f - -C $shareName+ --totals';
Finally, run visudo to change the allowed command to /path/to/tarCreate.
In this case, a compromise of the backuppc user still allows the attackerto run tar -c. But this only allows them read access to files on theserver, which they already have access to simply by inspecting theBackupPC backup data directories.
A similar setup with sudo can be used for rsync. See the SSH FAQ formore information.
Back to Top
文章来源于领测软件测试网 https://www.ltesting.net/