Sinnvolles Backup

Dieses Thema im Forum "Allgemein" wurde erstellt von darkness_08, 23. Aug. 2012.

  1. darkness_08

    darkness_08 Member

    Hallo

    Ich mache mir gerade Gedanken, wie ich ein Bakup auf einen externen Server durchführe.

    Grundsätzlich möchte ich das ganze per rsync durchführen.

    Das Verzeichnis /var/backup gehört standartmäßig root. Da ich das Backup nicht als root durchführen möchte, meine Frage:

    Kann ich die Gruppenenstellung des Verzeichnis ändern oder hat ISPConfig damit ein Problem?

    Zweite Frage:
    Kann man in die Backups der Benutzer auch die MySQL-Datenbanken mit integrieren?

    Gruß
     
  2. F4RR3LL

    F4RR3LL Member

    Du kannst an beliebigem Ort vor dem rsync sqldumps anlegen.
    Aber was hindert Dich zum rsyncen root zu benutzen? Das ist einfach am saubersten.

    Ohne es in ne Diskussion zu werfen, aber es gibt echt andere Schwachstellen als nen rootuser der via authkey einloggt.

    Gruß Sven
     
    Zuletzt bearbeitet: 23. Aug. 2012
  3. darkness_08

    darkness_08 Member

    Ich hätte gedacht das die Dumps von ISPConfig mit erzeugt werden. So hat jeder Nutzer seine Dumps. Ansonsten müsste ich ja für jeden Nutzer ein Script laufen lassen, oder eine Schleife mit den verschiedenen Nutzern. Und das mit dem root mag ich einfach nicht :) Aber notfalls geht das natürlich auch
     
  4. F4RR3LL

    F4RR3LL Member

    Schwaches Argument, aber jeder legt sich halt die Steine so in den Weg wie er es mag ;)


    Bzgl der Datenbank du kannst auch nen Sqldump mit allen Datenbanken auf einmal erstellen, das wird genau ein Dump.
    Codeschnipsel aus meinem Script:
    Code:
    /usr/bin/mysqldump -u root --password='totalgeheim' --all-databases > /pfad/zum/backup/all_dbs.sql
    
    ich lasse zwar auch alle Datenbanken nochmal extra sichern... aber mit obigem hat man einmal alles als Gesamtpaket.

    Gruß Sven
     
  5. darkness_08

    darkness_08 Member

    Ok, das Gesamtdump kenne ich. Wie machst du das mit den Einzeldumps
     
  6. F4RR3LL

    F4RR3LL Member

    Ich hab schlicht ein Script laufen das mir die Datenbanken auch nochmal einzeln als Dump zieht.
    Gruß Sven
     
  7. darkness_08

    darkness_08 Member

    ok, dann schaue ich mal.

    Danke schon mal
     
  8. neurex

    neurex Member

    Also ich habe mir nen Cron angelegt der ein Bashscript ausführt was nichts anderes macht als die Datenbank per mysqldump zu exportieren und dann einfach alle Verzeichnisse unter /srv/www rsynct.

    Hab dazu nen extra User auf dem Backupserver angelegt (PubKey-Methode) der nur für den rsync-Prozess root-Rechte hat. Funktioniert soweit ganz gut aber...

    ...lässt jemand von euch die Backups auf dem Server rotieren so das man verschiedene "Stände" einer Sicherung hat? Wenn ja gibts dafür schon ein Script oder ähnliches???
     
  9. darkness_08

    darkness_08 Member

    Ich habe es jetzt so gelöst:

    Per Cron werden auf dem Server die MySQL-Daten und verschiedene Verzeichnisse gesichert. Dabei mache ich ein komplettes DUMP der SQL-Datenbank und zusätzlich werden noch alles Datenbanken jeweils seperat gesichert.

    Das Backup auf einen anderen Server erfolgt dann per rsync und pub-Key.

    Bisher wird für jeden Tag ein neues Verzeichnis erstellt. Somit habe ich die möglichkeit ggf. verschiedene Stände zurück zuspielen.

    Einziger Nachteil bisher:
    Durch die umbenennung der ISP-Config-Backups (Neuste ist immer 1) werden diese jedemal per rsync komplett übertragen.
     
  10. gpi

    gpi New Member


    Hallo neurex,

    ich sichere wie folgt:


    Code:
    #!/bin/bash
    # backup.sh
    
    # Sicherung der mysql-Datenbanken
    
    BACKUP_DIR="/MyBackupDir/backup_sql_hourly"
    EXPIRETIME=3
    DATE=`date "+%Y-%m-%d_%H"`
    
    
    # Sicherung der mysql-Datenbanken
    
    for i in /var/lib/mysql/*/; do
            dbname=`basename "$i"`;
            mysqldump --user=backup_user -pmy_password  "$dbname" | bzip2 > $BACKUP_DIR/mysql/$dbname.$DATE.bz2
    done
    
    find $BACKUP_DIR/mysql -mtime +${EXPIRETIME} -exec rm {} \;
    
    Gruß

    Günter
     

Diese Seite empfehlen