Rdiff-backup : Différence entre versions
De wikiGite
Ligne 51 : | Ligne 51 : | ||
----------------- | ----------------- | ||
+ | Exemple de script rdbackup.sh | ||
+ | #!/bin/bash | ||
+ | # Script de sauvegarde des serveurs (RDIFF sur SSH) | ||
+ | # FSo 06/2010 | ||
+ | # v1.0 from sbackup.sh (RSYNC) v1.2 | ||
+ | # Changelog : | ||
+ | # | ||
+ | # svg_server.sh <hostname> <ip> <port> <user valide pour ssh> <duree retention> <fichier liste backup> <fichier exclusions> | ||
+ | # exemple cron.d : | ||
+ | #00 02 * * * root /backup/rdbackup.sh server.example.fr 123.123.12.123 22 root 1W /backup/server.list /backup/server.excl > /backup/log/svg_server.cron.err 2>&1 | ||
+ | # | ||
+ | SERVERNAME=$1 | ||
+ | SERVERIP=$2 | ||
+ | SERVERPORT=$3 | ||
+ | SERVERUSR=$4 | ||
+ | RETENTION="--remove-older-than $5" | ||
+ | LIST=$6 | ||
+ | EXCLUDE=$7 | ||
+ | BCK_DEV=/home | ||
+ | BCK_DIR=$BCK_DEV/backup/$SERVERNAME | ||
+ | LOG_FILE=rdiff_$SERVERNAME.log | ||
+ | STAT_FILE=rdiff_$SERVERNAME.stats | ||
+ | PID_FILE=/var/run/rdiff_$SERVERNAME.pid | ||
+ | RDIFF_OPTS="-v5 --force" | ||
+ | |||
+ | if [ $# -lt 6 ] | ||
+ | then | ||
+ | echo Usage : $0 serverFQDN serverIP serverSSHPORT SSHUSER RETENTION BACKUPLISTfile [EXCLUDEfile] | ||
+ | exit 1 | ||
+ | fi | ||
+ | |||
+ | shift; shift; shift | ||
+ | while read line | ||
+ | do | ||
+ | REMOTE_DIR="$REMOTE_DIR $line" | ||
+ | shift | ||
+ | done < $LIST | ||
+ | |||
+ | if [ ! -e $PID_FILE ] | ||
+ | then | ||
+ | echo $$ > $PID_FILE | ||
+ | /usr/bin/logger "Sauvegarde rdiff $SERVERNAME" | ||
+ | if [ -e $BCK_DIR/$LOG_FILE ] | ||
+ | then | ||
+ | mv $BCK_DIR/$LOG_FILE $BCK_DIR/$LOG_FILE.0 | ||
+ | fi | ||
+ | if [ -e $BCK_DIR/$STAT_FILE ] | ||
+ | then | ||
+ | mv $BCK_DIR/$STAT_FILE $BCK_DIR/$STAT_FILE.0 | ||
+ | fi | ||
+ | echo "Sauvegarde rdiff $SERVERNAME" > $BCK_DIR/$LOG_FILE | ||
+ | #Boucle de backup | ||
+ | ERROR_FLAG=0 | ||
+ | ERROR=0 | ||
+ | ERRORS="ERREURS: " | ||
+ | for rdir in $(echo $REMOTE_DIR) | ||
+ | do | ||
+ | if [ ! -d ${BCK_DIR}${rdir} ] | ||
+ | then | ||
+ | mkdir -p ${BCK_DIR}${rdir} | ||
+ | fi | ||
+ | |||
+ | if [ ! "x$EXCLUDE" == "x" ] | ||
+ | then | ||
+ | EXCLUDE_OPT="" | ||
+ | while read line | ||
+ | do | ||
+ | if [[ $line =~ ^$rdir ]] | ||
+ | then | ||
+ | EXCLUDE_OPT="$EXCLUDE_OPT --exclude $line" | ||
+ | fi | ||
+ | shift | ||
+ | done < $EXCLUDE | ||
+ | fi | ||
+ | # rdiff | ||
+ | date >> $BCK_DIR/$LOG_FILE | ||
+ | echo >> $BCK_DIR/$LOG_FILE | ||
+ | echo RDIFF-BACKUP OF $rdir >> $BCK_DIR/$LOG_FILE | ||
+ | echo rdiff-backup $RDIFF_OPTS --remote-schema "ssh -p $SERVERPORT %s rdiff-backup --server" $EXCLUDE_OPT $SERVERUSR@$SERVERIP::$rdir ${BCK_DIR}${rdir} >> $BCK_DIR/$LOG_FILE | ||
+ | rdiff-backup $RDIFF_OPTS --remote-schema "ssh -p $SERVERPORT %s rdiff-backup --server" $EXCLUDE_OPT $SERVERUSR@$SERVERIP::$rdir ${BCK_DIR}${rdir} >> $BCK_DIR/$LOG_FILE 2>&1 | ||
+ | ERROR=$? | ||
+ | if [ $ERROR -ne 0 ] | ||
+ | then | ||
+ | ERRORS="$ERRORS $BASE=$ERROR:" | ||
+ | ERROR_FLAG=1 | ||
+ | fi | ||
+ | echo CLEANING BACKUPS OF $rdir >> $BCK_DIR/$LOG_FILE | ||
+ | echo rdiff-backup $RDIFF_OPTS $RETENTION ${BCK_DIR}${rdir} >> $BCK_DIR/$LOG_FILE 2>&1 | ||
+ | rdiff-backup $RDIFF_OPTS $RETENTION ${BCK_DIR}${rdir} >> $BCK_DIR/$LOG_FILE 2>&1 | ||
+ | ERROR=$? | ||
+ | if [ $ERROR -ne 0 ] | ||
+ | then | ||
+ | ERRORS="$ERRORS $BASE=$ERROR:" | ||
+ | ERROR_FLAG=1 | ||
+ | fi | ||
+ | echo Backup statistics of $rdir >> $BCK_DIR/$STAT_FILE | ||
+ | cat ${BCK_DIR}${rdir}/rdiff-backup-data/session_statistics.$(date "+%Y-%m-%d")* >> $BCK_DIR/$STAT_FILE | ||
+ | echo >> $BCK_DIR/$STAT_FILE | ||
+ | done | ||
+ | if [ $ERROR_FLAG -eq 1 ] | ||
+ | then | ||
+ | (echo $ERRORS | ||
+ | date | ||
+ | echo Voir $BCK_DIR/$LOG_FILE | ||
+ | grep -i warning $BCK_DIR/$LOG_FILE | ||
+ | grep -i error $BCK_DIR/$LOG_FILE | ||
+ | cat $BCK_DIR/$STAT_FILE | ||
+ | )| mail -s "ERREUR RDIFF SUR $SERVERNAME $(date +%d/%m)" fsoyer@systea.net | ||
+ | else | ||
+ | (date | ||
+ | ls -l $BCK_DIR/$LOG_FILE | ||
+ | df -k $BCK_DIR | ||
+ | cat $BCK_DIR/$STAT_FILE | ||
+ | )| mail -s "Sauvegarde $SERVERNAME $(date +%d/%m) terminee" fsoyer@systea.net | ||
+ | fi | ||
+ | date >> $BCK_DIR/$LOG_FILE | ||
+ | /usr/bin/logger "FIN rdiff $SERVERNAME" | ||
+ | rm -f $PID_FILE | ||
+ | else | ||
+ | (echo "$SERVERNAME:$PID_FILE existe : abandon de $0") | mail -s "Erreur sur backup $SERVERNAME" fsoyer@systea.net | ||
+ | fi |
Version du 30 juillet 2010 à 10:46
A AJOUTER : procédure Windows
Sur Debian 5 --> v1.2.5 (la différence de version mineure (.5 pour .8) ne provoque qu'un avertissement)
apt-get install rdiff-backup
Si on veut une version plus récente, il faut compiler :
apt-get install librsync-dev python-dev wget http://savannah.nongnu.org/download/rdiff-backup/rdiff-backup-1.2.8.tar.gz tar -xvzf rdiff-backup-1.2.8.tar.gz cd rdiff-backup-1.2.8 python setup.py install
Sur CentOS, installation repos RPMForge (http://wiki.centos.org/AdditionalResources/Repositories/RPMForge).
Sur CentOS4 :
wget http://packages.sw.be/rpmforge-release/rpmforge-release-0.5.1-1.el4.rf.i386.rpm
Sur CentOS5 :
wget http://packages.sw.be/rpmforge-release/rpmforge-release-0.5.1-1.el5.rf.i386.rpm
Puis
rpm -i rpmforge-release-0.5.1-1.el*.rf.i386.rpm vi /etc/yum.repos.d/rpmforge.repo # --> mettre enabled à 0 yum --enablerepo=rpmforge install rdiff-backup
Test d'accès à un serveur :
rdiff-backup --test-server root@192.168.1.21::/home
Sauvegarde à partir d'un backup existant (cp ou rsync) : le répertoire destination existe mais n'est pas au format rdiff (manque les infos rdiff-data), il faut le forcer la première fois :
rdiff-backup --force -v5 root@192.168.1.2::/etc /backup/etc > rdiff_server1.log 2>&1
Ensuite on peut enlever le "--force".
Nettoyage Des incréments supérieurs à une fenêtre de rétention :
rdiff-backup -v5 --remove-older-than 4W /backup
Le "4W" signifie "4 weeks", soit 4 semaines à conserver. On peut donner un nombre de jours ("D") ou d'heures ("H"). Tous les incréments supérieurs à ce délai seront supprimés.
Liste des incréments :
Sur le serveur de sauvegarde :
rdiff-backup -l /home/backup/server1/home/
A partir du serveur sauvegardé (remote-schema n'est utile que si le port ssh n'est pas standard) :
rdiff-backup -l --remote-schema='ssh -p 225 -C %s rdiff-backup --server' root@192.168.1.250::/home/backup
Restore - Exemples
# /etc/hosts d'il y a 1 heure (--force si le fichier existe et qu'il faut l'écraser) rdiff-backup -v5 -r "1h" --force ./etc/hosts root@192.168.1.2::/etc/hosts
# /etc/ d'il y a 3 jours rdiff-backup -v5 -r "3D" --force ./etc root@192.168.1.2::/etc
Exemple de script rdbackup.sh
#!/bin/bash # Script de sauvegarde des serveurs (RDIFF sur SSH) # FSo 06/2010 # v1.0 from sbackup.sh (RSYNC) v1.2 # Changelog : # # svg_server.sh <hostname> <ip> <port> <user valide pour ssh> <duree retention> <fichier liste backup> <fichier exclusions> # exemple cron.d : #00 02 * * * root /backup/rdbackup.sh server.example.fr 123.123.12.123 22 root 1W /backup/server.list /backup/server.excl > /backup/log/svg_server.cron.err 2>&1 # SERVERNAME=$1 SERVERIP=$2 SERVERPORT=$3 SERVERUSR=$4 RETENTION="--remove-older-than $5" LIST=$6 EXCLUDE=$7 BCK_DEV=/home BCK_DIR=$BCK_DEV/backup/$SERVERNAME LOG_FILE=rdiff_$SERVERNAME.log STAT_FILE=rdiff_$SERVERNAME.stats PID_FILE=/var/run/rdiff_$SERVERNAME.pid RDIFF_OPTS="-v5 --force" if [ $# -lt 6 ] then echo Usage : $0 serverFQDN serverIP serverSSHPORT SSHUSER RETENTION BACKUPLISTfile [EXCLUDEfile] exit 1 fi shift; shift; shift while read line do REMOTE_DIR="$REMOTE_DIR $line" shift done < $LIST if [ ! -e $PID_FILE ] then echo $$ > $PID_FILE /usr/bin/logger "Sauvegarde rdiff $SERVERNAME" if [ -e $BCK_DIR/$LOG_FILE ] then mv $BCK_DIR/$LOG_FILE $BCK_DIR/$LOG_FILE.0 fi if [ -e $BCK_DIR/$STAT_FILE ] then mv $BCK_DIR/$STAT_FILE $BCK_DIR/$STAT_FILE.0 fi echo "Sauvegarde rdiff $SERVERNAME" > $BCK_DIR/$LOG_FILE #Boucle de backup ERROR_FLAG=0 ERROR=0 ERRORS="ERREURS: " for rdir in $(echo $REMOTE_DIR) do if [ ! -d ${BCK_DIR}${rdir} ] then mkdir -p ${BCK_DIR}${rdir} fi if [ ! "x$EXCLUDE" == "x" ] then EXCLUDE_OPT="" while read line do if $line =~ ^$rdir then EXCLUDE_OPT="$EXCLUDE_OPT --exclude $line" fi shift done < $EXCLUDE fi # rdiff date >> $BCK_DIR/$LOG_FILE echo >> $BCK_DIR/$LOG_FILE echo RDIFF-BACKUP OF $rdir >> $BCK_DIR/$LOG_FILE echo rdiff-backup $RDIFF_OPTS --remote-schema "ssh -p $SERVERPORT %s rdiff-backup --server" $EXCLUDE_OPT $SERVERUSR@$SERVERIP::$rdir ${BCK_DIR}${rdir} >> $BCK_DIR/$LOG_FILE rdiff-backup $RDIFF_OPTS --remote-schema "ssh -p $SERVERPORT %s rdiff-backup --server" $EXCLUDE_OPT $SERVERUSR@$SERVERIP::$rdir ${BCK_DIR}${rdir} >> $BCK_DIR/$LOG_FILE 2>&1 ERROR=$? if [ $ERROR -ne 0 ] then ERRORS="$ERRORS $BASE=$ERROR:" ERROR_FLAG=1 fi echo CLEANING BACKUPS OF $rdir >> $BCK_DIR/$LOG_FILE echo rdiff-backup $RDIFF_OPTS $RETENTION ${BCK_DIR}${rdir} >> $BCK_DIR/$LOG_FILE 2>&1 rdiff-backup $RDIFF_OPTS $RETENTION ${BCK_DIR}${rdir} >> $BCK_DIR/$LOG_FILE 2>&1 ERROR=$? if [ $ERROR -ne 0 ] then ERRORS="$ERRORS $BASE=$ERROR:" ERROR_FLAG=1 fi echo Backup statistics of $rdir >> $BCK_DIR/$STAT_FILE cat ${BCK_DIR}${rdir}/rdiff-backup-data/session_statistics.$(date "+%Y-%m-%d")* >> $BCK_DIR/$STAT_FILE echo >> $BCK_DIR/$STAT_FILE done if [ $ERROR_FLAG -eq 1 ] then (echo $ERRORS date echo Voir $BCK_DIR/$LOG_FILE grep -i warning $BCK_DIR/$LOG_FILE grep -i error $BCK_DIR/$LOG_FILE cat $BCK_DIR/$STAT_FILE )| mail -s "ERREUR RDIFF SUR $SERVERNAME $(date +%d/%m)" fsoyer@systea.net else (date ls -l $BCK_DIR/$LOG_FILE df -k $BCK_DIR cat $BCK_DIR/$STAT_FILE )| mail -s "Sauvegarde $SERVERNAME $(date +%d/%m) terminee" fsoyer@systea.net fi date >> $BCK_DIR/$LOG_FILE /usr/bin/logger "FIN rdiff $SERVERNAME" rm -f $PID_FILE else (echo "$SERVERNAME:$PID_FILE existe : abandon de $0") | mail -s "Erreur sur backup $SERVERNAME" fsoyer@systea.net fi