Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 29 Dec 2003 11:14:14 -0500
From:      "C. Ulrich" <dincht@securenym.net>
To:        Joachim Dagerot <joachim@dagerot.nu>
Cc:        freebsd-questions@freebsd.org
Subject:   Re: Incremental backup solution. was: What logs etc do I need tocheckfrequently?
Message-ID:  <200312291619.hBTGJdt22787@anon.securenym.net>
In-Reply-To: <200312290935.hBT9Zo423698@thunder.trej.net>
References:  <200312290935.hBT9Zo423698@thunder.trej.net>

next in thread | previous in thread | raw e-mail | index | archive | help
On Mon, 2003-12-29 at 04:35, Joachim Dagerot wrote:
> This solution sounds nice, I can even imagine setting up an additional
> machine (on the same location though) to have a somewhat galvanic
> isolation between the disks. Only fire, earthquake and a neutronbomb
> would affect such a backup solution.
> 
> However, I could use a push in the right direction when it comes to
> how to configure and what software to use for achieving the
> incremental backup tasks.
> 
> Could you hint me in how your system is doing this in a more detailed
> way?
> 
> Cheers,
> Joachim

I'd be glad to. First, it's actually a Linux system, though there's
nothing particularly Linux-specific about it except the device names and
the method of spinning down the backup disk after the job. 

The cornerstone of the solution is the rdiff-backup program
(http://rdiff-backup.stanford.edu/ or in ports at
/sysutils/rdiff-backup). rdiff-backup is a python script that mirrors
one directory to another. It can do incremental backups and it can do
them either locally or remotely. It's really a slick piece of software
and I'm continually surprised that it doesn't get more publicity.

First, there's the (trivial) script /usr/local/sbin/backup-share.sh.
This is run by a daily cron job to backup directories on the disk that
contain Important Data. Mine is very specific to my system. It is *not*
pretty and I plan to overhaul it sometime soon to include error handling
and an external config file.

#!/bin/bash
# script to automatically back up the important stuff on /nfs/share
prog=/usr/local/bin/rdiff-backup
src=/nfs/share
dst=/backup/share
budirs="code emu images media music school software text webpage"
mount /backup
for dir in $budirs
do 
  $prog $src/$dir $dst/$dir
done
umount /backup
# put backup drive in sleep mode since we won't be needing
#       it again for the next 24 hours or so
hdparm -qY /dev/hdd

A note about the last line: it appears that FreeBSD can only spin-down
SCSI disks on command. (See camcontrol(8).) The best way to power down
IDE disks seems to be just setting a suspend timeout in the power
management section of your BIOS. Once the disk is unmounted, FreeBSD
won't touch it thereafter and the system should put it in suspend mode
automatically.

The crontab entry looks like this:

# backup selected dirs in /nfs/share @ 0730 daily
30 07 * * * sh /usr/local/sbin/backup-share.sh

That's really about it. Like I said before, moving the backup disk to a
separate machine would be trivial. If there are any questions, I'd be
glad to answer them.

Charles Ulrich
-- 
http://bityard.net



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200312291619.hBTGJdt22787>