From 60432b45d7b084c6264e99233c49d99bc9cc52d8 Mon Sep 17 00:00:00 2001 From: Alan Jack Pippin <ajp@pippin.(none)> Date: Sun, 13 Nov 2005 00:50:10 -0700 Subject: [PATCH] Added support for new excludedir configuration option. Added some simple error detection and cleanup. Added support to properly exclude files from find cmd. --- scripts/config.sh | 4 +++ scripts/pack-image.sh | 79 +++++++++++++++++++++++++++++++++++++------ 2 files changed, 72 insertions(+), 11 deletions(-) diff --git a/scripts/config.sh b/scripts/config.sh index 056bb2c..bfe1847 100755 --- a/scripts/config.sh +++ b/scripts/config.sh @@ -23,3 +23,7 @@ backupdirs=" /var/lib/iptables /var/lib/mailman " + +excludedirs=" +" + diff --git a/scripts/pack-image.sh b/scripts/pack-image.sh index 9dcc6bf..f2aae3e 100755 --- a/scripts/pack-image.sh +++ b/scripts/pack-image.sh @@ -19,44 +19,101 @@ isoimage="$imagedir/$today.img" isomountdir="$isoimage.mnt" restorescript="$scriptsdir/restore.sh" -echo "Creating directories" +echo "-> Creating directories" mkdir --mode=700 -p $datadir $imagedir $isomountdir $tmpdir - -echo "Creating the iso image in $isoimage" +if [ $? != 0 ] +then + if test -d $isomountdir + then + rm -rf $isomountdir + fi + echo "-E- Unable to create the following directories: " + echo " $datadir $imagedir $isomountdir $tmpdir" + exit -1 +fi + +echo "-> Creating the iso image in $isoimage" dd if=/dev/null of=$isoimage bs=1M count=0 seek=4440 mke2fs -b 2048 -F $isoimage +if [ $? != 0 ] +then + rm -rf $isomountdir $isoimage + echo "-E- Unable to create the iso image: $isoimage" + exit -1 +fi -echo "Mounting the iso image" +echo "-> Mounting the iso image" mount -t ext2 -o loop $isoimage $isomountdir +if [ $? != 0 ] +then + rm -rf $isomountdir $isoimage + echo "-E- Unable to mount the iso image: $isoimage -> $isomountdir" + exit -1 +fi + +echo "-> Directories being backedup and excluded:" +echo "backupdirs: $backupdirs" +echo "excludedirs: $excludedirs" -echo "Running find to get the status of files" +echo "-> Running find to get the status of files" { for type in d f l; do findformat="$type %#m %u %g %s %CY%Cm%Cd%CH%CM%CS 0 %p\0" - find $backupdirs -type $type -printf "$findformat" + if [ -z $excludeddirs ] + then + find $backupdirs -type $type -printf "$findformat" + else + regex=`echo $excludedirs | sed -e 's/ /.*\\\\|/g'` + regex=`echo "'\($regex.*\)'"` + find $backupdirs -type $type -o -regex $regex -prune -o -printf "$findformat" + fi done } > $currentfiles -echo "Determining list of files to backup with lsbackups" +echo "-> Determining list of files to backup with lsbackups" { # lsbackups expects the current date followed by a null before the list of files printf "$today\0" cat $currentfiles } | lsbackups > $backups 2>$statusfile -echo "Running rsync to pack the image" +echo "-> Running rsync to pack the image" rsyncopts="-W -H -S -l -p -t -g -o -0 --files-from=- --stats --progress" cat $backups | rsync $rsyncopts / $isomountdir +if [ $? != 0 ] +then + umount $isomountdir + rm -rf $isomountdir $isoimage + echo "-E- Unable to rsync to pack the image" + exit -1 +fi -echo "Copying over database and status file" +echo "-> Copying over database and status file" cp $statusfile $backupdb $restorescript $isomountdir +if [ $? != 0 ] +then + echo "-E- Unable to copy the database and status file" + exit -1 +fi -echo "Unmounting image" +echo "-> Unmounting image" umount $isomountdir +if [ $? != 0 ] +then + echo "-E- Unable to unmount the iso dir: $isomountdir" + exit -1 +fi -echo "Calculating md5sum for image" +echo "-> Calculating md5sum for image" md5sum $isoimage | awk '{print$1}' > $isoimage.md5sum +if [ $? != 0 ] +then + echo "-E- Unable to calculatethe md5sum for this image: $isoimage" + exit -1 +fi cat $statusfile | mailx -s "DVD image available to burn - $today" $mailto echo $today > $lastbackupfile + + -- 2.34.1