[CentOS] Best backup software for linux

Mark Schoonover schoon at amgt.com
Mon Nov 6 22:54:14 UTC 2006


Les Mikesell wrote:
> On Mon, 2006-11-06 at 18:42 +0000, Peter Crighton wrote:
> 
>> You wrote "Hardlinks are key to this backup strategy. Using cp -al
>> creates hardlinks to files, and this simple command is what does all
>> the heavy lifting for daily and weekly backups. Wikipedia has a very
>> good explanation on how hardlinks work. In a nutshell, when there's a
>> hardlink pointing to a file from the hourly directory, to a file in
>> the current directory, and that current file gets deleted, all the
>> links that point to that now deleted current file gets the file data
>> 'pushed' back towards all the links. I'll have to think how to
>> explain this better." 
>> 
>> Do you mean that the hourly files are written when created, the
>> hardlink for the daily doesn't actually copy the file (simply makes a
>> link), but if the file is set to be deleted from it's location
>> (because it's gone from the server) then it is actually moved so that
>> it still exists in the daily backup  but is removed from the hourly?
>> --
> 
> Think of all directory entries as links.  The real entries that
> map disk space to files are inodes and links are names pointing
> to the inodes.  There can be any number - including 0 - of links
> to an inode.  The space is not released for re-use until the
> link count goes to 0 and no process has the file open.  So hardlinks
> are just multiple names pointing to the same data, and the data
> doesn't go away until the last name is removed.  

You did much better explaining what's going on with hardlinks than I did.
I'm going to have to rewrite that part of the blog a few times before it
reads better. I can picture it all in my head, but describing how it works
is another.

>Note that this only works as a backup if the original filename is removed.
If it
>is overwritten or truncated instead, all links now point to the changed
version.

This is true if you're doing it with only filesystem tools, but this system
is using rsync. What's happening is the cp -al occurs first making hardlinks
that point to an hourly directory into the current directory, then rsync is
run to update current. Because rsync will create a new temp file when any
file changes, the original is deleted with it's data 'pushed' to any
hardlinks pointing at the original file. Rsync then renames the temp file
the original file name that has changed, therefore assuring that any
hardlinks will always have the previous copy of any changed files. With
rsync running in --delete mode, any files from the source server that get
deleted, will get deleted out of current in the backup server, causing this
cascade of hardlinks to get updated with the deleted files data. That's how
this system can create incremental backups of only changed data, but with
hardlinks, it looks like full backups are made each and every time. Really
saves disk space, that's for sure!

Hope this clears things up...

Mark





More information about the CentOS mailing list