X-Git-Url: http://git.pippins.net/embedvideo/.git/static/gitweb.js?a=blobdiff_plain;f=scripts%2Frestore-script.sh;h=62042d570263fb9d5adbce2f3d5a691e80a4827f;hb=575a6caced28aeb051f876d1c3db1a8188164685;hp=acd90081c17aa632ec6d17c1de9290491935e1d6;hpb=ec0fa7c570c25174b2749ec2314746cb1d513ab8;p=backups%2F.git diff --git a/scripts/restore-script.sh b/scripts/restore-script.sh index acd9008..62042d5 100755 --- a/scripts/restore-script.sh +++ b/scripts/restore-script.sh @@ -1,29 +1,35 @@ #!/bin/sh -if [ -z "$mountdir" ]; then - echo >&2 '$mountdir must be set' +function err() { + echo >&2 "-E- $1" exit 1 -fi +} -if [ -z "$rundir" ]; then - echo >&2 '$rundir must be set' - exit 1 -fi +[ -n "$3" ] && mountdir=$3 + +[ -z "$mountdir" ] && err '$mountdir must be set' +[ -z "$rundir" ] && err '$rundir must be set' export PATH=${rundir%%/}:/bin:/usr/bin:/sbin:/usr/sbin:/sw/bin -if [ $# != 2 -o ! -d "$1" -o ! -d "$2" ]; then - echo >&2 "Usage: $0 " - echo >&2 "Example: $0 / /" - exit 1 +if [ ! -z "$1" -o ! -d "$2" ]; then + err " +Usage: $0 [] + source-dir - directory on backup disks to restore from (relative to $mountdir) + relocate-dir - base directory to restore files to (usually /) + mnt-dir - directory where backup disk is mounted (optional) + + Examples: + % $0 / / /mnt/cdrom # Restore everything from disks (explicitly specifying dvd mount point.) + % $0 / / # Restore everything from disks + % $0 /home / # Restore only files under /home on disks to /home on the system + % $0 /home /home # Restore files under /home on disks to /home/home on the system (probably not what you want.) +" fi device=$(mount | grep "on ${mountdir%%/} " | awk '{print$1}') -if [ -z "$device" ]; then - echo >&2 "Cannot determine cdrom device" - exit 1 -fi +[ -z "$device" ] && err "Cannot determine cdrom device" cp ${mountdir%%/}/backups.db ${mountdir%%/}/backup-status.txt $rundir dbfile=${rundir%%/}/backups.db @@ -31,10 +37,16 @@ dbfile=${rundir%%/}/backups.db dates=$(cat $dbfile | list-dates.sh) for date in $dates; do + filelist=$(tempfile) + # Check to see if files are actually needed from the current disk before requesting it. + cat $dbfile | files-from-date.sh $date | grep -z -Z -e "^${1%%/}/" > $filelist + if [ -s $filelist ]; then success=false while ! $success; do eject $device - echo >&2 "Please insert backup disk: $date" + [ $? != 0 ] && err "Cannot eject the disk. Drive is busy. Run lsof $mountdir to see why." + echo "Please insert backup disk: $date" + echo "Press Enter to continue" read bogus eject -t $device @@ -44,10 +56,14 @@ for date in $dates; do if grep -q $date ${mountdir%%/}/backup-status.txt; then success=true else - echo >&2 "This doesn't seem to be the right disk." + echo "This doesn't seem to be the right disk." fi done - rsyncopts="-l -p -t -g -o -0 --files-from=- --stats --progress" - cat $dbfile | files-from-date.sh $date | rsync $rsyncopts ${mountdir%%/}/ ${2%%/}/ + rsyncopts="-W -H -S -l -p -t -g -o -0 --files-from=- --stats --progress" + cat $filelist | rsync $rsyncopts ${mountdir%%/}/ ${2%%/}/ + else + echo "No files are needed from disk: $date. Skipping it." + fi + rm -f $filelist done