Beispiel eines vollautomatisierten Backups

Aus wiki.archlinux.de

„Beispiel eines vollautomatisierten Backups“ wurde von Chepaz (Diskussion) als in Bearbeitung markiert. Um Bearbeitungskonflikte zu vermeiden, kontaktiere Chepaz (Diskussion) bitte, bevor du den Artikel bearbeitest.


Beispiel eines vollautomatisierten Backups

Einleitung

Das hier soll eher ein Denkanstoss sein wie man Backups automatisieren kann. Es ist und soll keine "copy & paste" Anleitung sein und auch ein paar Gedanken über Backups selber vermitteln.


Backups zu automatisieren hat fast nur Vorteile:

  • man vergisst sie nicht.
  • man muss sie nicht von Hand anstossen.
  • man kann sie, einmal eingerichtet, solange vergessen bis man sie braucht ;)

Nachteile gibt es aber auch:

  • der Speicher auf den das Backup soll muss (zur passenden Zeit) erreichbar sein.
  • evtl. bekommt man nicht mit das gar kein Backup gelaufen ist!


Vorüberlegung

  • Vorraussetzung um ein Backup zu automatisieren ist natürlich das es keinerlei manueller Intervention bedarf. Das bedeutet schonmal das sämtliche Geräte bei denen man ein Kabel einstecken müsste oder die man manuell einschalten muss aussen vor bleiben.
  • Allerdings will man evtl. auch nicht das ein Gerät (Server) 24/7 läuft und zu 95% Strom sinnlos in Wärme umwandelt.
  • der Speicherort sollte "extern" liegen, d.h. nicht auf dem Gerät von dem man ein Backup macht! Wie weit man "extern" ausdehnt sei jedem selbst überlassen (Physikalisch auf jeden Fall. Aber ob Räumlich im sinne von Raum oder sogar Gebäude... feel free ;) )
  • man benötigt eine Form von Monitoring.


Aus diesen Punkten kann man z.B. folgendes entwickeln:

  • ein Backupserver (optional mit RAIDx) der nur bei Bedarf läuft und Speicherplatz bereitstellt.
  • Clients die nicht immer am Netz sind aber automatisch ihr Backup darauf ablegen.


Erste Schritte

Server

  • Auf dem Server richtet man zuerst Shares ein, z.B. Nfs oder Samba den die Clients für ihr Backup nutzen sollen.


Client

  • Die Clients bekommen ein Share vom Server das sie automounten. Das kann man per autofs erledigen oder auch durch systemd machen lassen.
  • Auf den Clients wird rsnapshot eingerichtet welches in dem automount sein Backup anlegt.


Jetzt hat man schonmal ein rudimentäres Setup für sein Backup geschaffen. Es fehlt nur noch der Schritt zur Automation.


Automatisierung & Stromsparen

Server

Um Strom zu sparen richtet man Server bei inaktivität im Netz schlafen legen ein.


Client

Wie in Server bei inaktivität im Netz schlafen legen beschrieben installiert man auf den Clients wol um den Server auf zu wecken wenn er schläft. Dann benötigt man noch folgendes Script welches man z.B. unter /root/scripts/auto-backup.sh ablegt und ausführbar macht:

 #!/bin/bash
 # Author: chepaz <mx-bounce@gmx.net>
 #
 # config server details here
 wakethismac="aa:bb:cc:dd:ee:ff"
 bkuphost="hostname"
 bkuphosttimeout="12" # is a multiple of 10s e.g. 12*10 fail after 120s
 
 # parametercheck
 if [ $# -ne 1 ]; then
     echo "Too much or too few parameters."
     echo "Use one of: <hourly | daily | weekly | monthly>"
     exit 1
 fi
 
 if [ $1 == "hourly" ]; then
     bkuptype=$1
 elif [ $1 == "daily" ]; then
     bkuptype=$1
 elif [ $1 == "weekly" ]; then
     bkuptype=$1
 elif [ $1 == "monthly" ]; then
     bkuptype=$1
 elif [ $1 == "yearly" ]; then
     bkuptype=$1
 elif [ $1 == "backup" ]; then
     bkuptype=$1
 else
     echo "Use one of: <hourly | daily | weekly | monthly | yearly | backup>"
     exit 1
 fi
 
 # wake up your backupserver
 wol $wakethismac &>/dev/null 
 
 
 # check if destination is reachable
 statusfile="/tmp/$!.status"
 echo "false" > $statusfile
 
 while [ $(grep false $statusfile) ]; do
     ping -c1 $bkuphost &>/dev/null
     pingstatus=$?
 
     if [ $pingstatus -eq "0" ]; then
         echo "true" > $statusfile
     fi
     
     # avoid pingspam and quit if backuphost isn't reachable
     if [ $pingstatus -eq "1" ]; then
         if [ $bkuphosttimeout -eq "0" ]; then
             echo "Destination unreachable, NO BACKUP MADE!"
             exit 404
         fi
         sleep 10
         ((bkuphosttimeout--))
     fi
 done
 
 
 # run the backup 
 rsnapshot -q $bkuptype
 
 
 # check if rsnypshot was successful
 if [ $? -eq "0" ]; then
     rm $statusfile
 else
     echo "Backup failed, take a look at the rsnapshot logs!"
 fi
 chmod +x /root/scripts/auto-backup.sh

Dem Script kann man die Optionen hourly, daily, weekly, yearly und backup mitgeben. yearly und backup sind Sonderkonstrukte die man sich bei Bedarf in seine rsnapshot.conf einpflegen kann oder auch einfach ignorieren ;)

Der Sinn des Scriptes ist es rsnapshot den passenden Parameter mitzugeben mit dem gebackupt werden soll (hourly,daily,weekly per default), den Server zu wecken und vor dem Backup zu testen ob er erreichbar ist. Falls das nicht der Fall sein sollte bricht das Script ab ohne rsnapshot aufzurufen. Vor dem Aufruf muss man folgende Variablen konfigurieren:

  • wakethismac="aa:bb:cc:dd:ee:ff" <-- mit der MAC-Adresse des Servers
  • bkuphost="hostname" <-- mit dem Hostnamen des Servers mit dem er im DNS erreichbar ist
  • bkuphosttimeout="12" <-- wann das Script bei Nichterreichbarkeit abbricht (z.B. 1x10s minimum, 4x10s nach 40s usw.)

Jetzt kann man z.B. in /etc/cron.daily ein File anlegen

 echo "/root/scripts/auto-backup.sh daily" > /etc/cron.daily/backup

und anacron sorgt dafür das es jeden Tag einmal ausgeführt wird.

Das gleiche kann man nun auch in /etc/cron.[hourly|weekly|monthly] anstellen. Ab sofort wird automatisch ein Backup gemacht wenn der Server erreichbar ist.


Ein bischen Monitoring

Ein ganz einfaches Monitoring erreicht man wenn man z.B. Postfix installiert und wie beschrieben nur lokale Mails aktiviert. Wenn rsnapshot oder das Script durch Fehler abbrechen bekommt root automatisch eine Mail. Das ist zugegebenermaßen nicht die Welt aber wer schaut sich daheim ernsthaft jeden Tag Logfiles durch?