#!/bin/sh
+# Locking
+LOCKFILE=/home/backup/backuprun.lockfile
+
+# Die gracefully (ie. remove lockfile)
+die() {
+ rm $LOCKFILE
+ exit 255
+}
+
+trap die SIGINT SIGTERM
+
+if [ -e $LOCKFILE ]; then
+ echo `date`": $LOCKFILE exists, exiting."
+ exit 1
+fi;
+touch $LOCKFILE
+
#dirs
confdir=/home/backup/conf/ #configuration files
storagedir=/backup #mountpoint of huge disc
export PATH
#start the logfile
-date
-echo
+echo `date`": Backup run starting"
echo "Exclude pattern:"
cat $exclude
-echo
-echo
+echo "End exclude pattern"
umask 027
if [ "$backuplevel" = "daglig" ] || [ "$backuplevel" = "incremental" ]
then
lastd=`cat ../.date`
- lastcmd="--newer=\"$lastd\""
+ lastcmd="--newer='$lastd'"
else
lastcmd=""
fi
exf=`ssh $computer "ls ~/.backup/exclude"`
#We try to run tar on the remote computer
- # C is instead of 'cd $filesystem'
- # - is 'this directory'
- # l is 'stay in local filesystem
- echo "cmdline: $tar cfCl - $filesystem . $lastcmd --exclude-from=$exf | gzip"
- if `ssh -c blowfish $computer "$tar cfCl - $filesystem . $lastcmd \
- --exclude-from=$exf \
- | gzip" \
- | dd of=$DATE.tmp 2>/dev/null`
- then
+ # c create archive
+ # C change to directory first
+ # - output to stdout (we pipe to gzip, then to dd)
+ # . where to start taring (see C)
+ # $lastcmd only files newer than this
+ # --exclude-from file to get exclusion pattern from
+ # pipe to gzip, which in turn pipes over the ssh-stream
+ # ..to dd, to output to a file. We surpress messages from dd.
+ # And at last, redirect stderr to stdout, to get output logged.
+ TARFILE=$DATE.tmp
+ TARCMD="ssh $computer \"$tar --one-file-system -cf - -C $filesystem . $lastcmd \
+ --exclude-from=$exf | gzip\" | (dd of=$TARFILE 2> /dev/null) 2>&1"
+ echo "cmdline: $TARCMD"
+ eval $TARCMD
+
+ # Ideally, we should check wether the tar command returned 0 or not, but it
+ # seems a pipe in bash returns the value of the last command in the pipe.
+ # Instead, we check wether the resulting file has zero size, in which case we
+ # consider it an error.
+ if [ -s $TARFILE ]; then
+ echo `date`": command probably ran without errors."
#perhaps it did work
- mv $DATE.tmp $DATE.tgz
+ mv $TARFILE $DATE.tgz
#make a filelist.
#update the datefile if the filelist is ok.
tar tvfz $DATE.tgz > $DATE.idx 2>&1 &&
else
#it did not work
- rm $DATE.tmp 2>/dev/null
- echo "$backuplevel backup of $computer:$filesystem failed and deleted"
- # TODO send mail!
+ rm $TARFILE
+ echo `date`": $TARFILE empty. $backuplevel backup of $computer:$filesystem failed and deleted"
fi
}
for computer in $unixcomputers
do
(
+ echo `date`": Backing up $computer"
+
+ # Try to SSH to the computer without entering a password.
+ if `ssh -n -o NumberOfPasswordPrompts=0 $computer /bin/true`; then
+ echo "Passwordless SSH to $computer works."
+ else
+ echo "Could not use passwordless SSH to $computer."
+ break;
+ fi
+
#tømmer variabelen for sikkerhets skyld
filesystems=""
| grep -v "^$" \
| awk '{ if ( $(NF-1) != "0" ) print $2}' `
+ echo "Filesystems to backup on $computer: $filesystems"
+
#clean up our dir at this client
- ssh $computer "rm -r ~/.backup ; mkdir -m 700 ~/.backup"
+ if ! ssh $computer "rm -r ~/.backup ; mkdir -m 700 ~/.backup"; then
+ echo "Could not create backup staging area at $computer:~/.backup"
+ break;
+ fi
#try to copy $exclude to $computer
- scp $exclude $computer:~/.backup/exclude ||
- echo "could not copy exclude.txt to $computer :("
+ if ! scp $exclude $computer:~/.backup/exclude > /dev/null; then
+ echo "Could not copy exclude.txt to $computer"
+ break;
+ fi
#try to copy preeexec and postexec if they exist
- [ -f $confdir/preexec.$computer ] &&
- scp $confdir/preexec.$computer $computer:~/.backup/preexec
- [ -f $confdir/postexec.$computer ] &&
- scp $confdir/postexec.$computer $computer:~/.backup/postexec
+ [ -f $confdir/preexec.$computer ] && (
+ scp $confdir/preexec.$computer $computer:~/.backup/preexec ||
+ ( echo "Could not copy preexec.$computer to $computer:~/.backup/preexec"; break )
+ )
+ [ -f $confdir/postexec.$computer ] && (
+ scp $confdir/postexec.$computer $computer:~/.backup/postexec ||
+ ( echo "Could not copy postexec.$computer to $computer:~/.backup/postexec"; break )
+ )
#try to run preexec if it exist
ssh $computer "[ -f ~/.backup/preexec ] && /bin/bash -x ~/.backup/preexec"
#lager det som trengs av kataloger
mkdir -m 755 -p $storagedir/$computer/$sfilesystem/{full,daglig} 2>/dev/null
- #
echo $filesystem > ${storagedir}/${computer}/.${sfilesystem}.name
chmod 644 ${storagedir}/${computer}/.${sfilesystem}.name
fi
#sjekker om det er på tide med en full
- if
- [ -z "`find $storagedir/$computer/$sfilesystem/full/ -name \*tgz -mtime -$dagermellomfulle`" ]
- then
+ if [ -z "`find $storagedir/$computer/$sfilesystem/full/ -name \*tgz -mtime -$dagermellomfulle`" ]; then
backuplevel=full
fi
#gå ned i rett katalog, eller dø
# TODO bør sende mail om dette skjer!
- cd $storagedir/$computer/$sfilesystem/$backuplevel || exit 1
+ cd $storagedir/$computer/$sfilesystem/$backuplevel || die
#perform the actual backup
backup
wait
-#create report
-/home/backup/report.sh $storagedir > /tmp/report.txt
-#[ ! -z $remotestat ] && scp /tmp/report.txt $remotestat
-###
-
# print diskusage to logfile
-df -k
+echo "Current disk usage:"
+df -k $storagedir
+
+echo `date`": Backup run ended"
-date