Datenwiederherstellung aus Backup: Unterschied zwischen den Versionen

Aus Glaskugel
Zur Navigation springen Zur Suche springen
 
(7 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 13: Zeile 13:
===1. Backup mounten===
===1. Backup mounten===
:;1.1 Anmeldung im Cloudpit
:;1.1 Anmeldung im Cloudpit
::bei Shared-Servern (wwwxx, Mädchenname) Anmeldung mit Nutzer ''estugo_webhosting''
::bei Managed vServern Anmeldung mit Nutzer ''estugo''
::(https://cloudpit.io/auth/login) Zgd. findest du in Keepass


:;1.2 Suche mittels Suchfunktion den Container, für welchen du das Backup einspielen möchtest  
:;1.2 Suche mittels Suchfunktion den Container, für welchen du das Backup einspielen möchtest  
::(z.B www70.estugo.de)
    
    
:;1.3 Suche dir unter "Datensicherung" das vom Kunden gewünschte Backup raus  
:;1.3 Suche dir unter "Datensicherung" das vom Kunden gewünschte Backup raus  
::(z.B vom 30.01.)
    
    
:;1.4 Klicke unter Aktionen auf '''"Backup mounten"'''
:;1.4 Klicke unter Aktionen auf '''"Backup mounten"'''
Zeile 29: Zeile 24:
::Das Backup befindet sich nun im Ordner /mnt
::Das Backup befindet sich nun im Ordner /mnt


===2. Ordner backup_estugo erstellen===
===2. Ordner backup_*datum* erstellen===
:;Melde Dich als ''admin'' im Plesk an
:;Melde Dich als ''admin'' im Plesk an


:;Wechsele in das Abo des Kunden
:;Wechsele in das Abo des Kunden


::Lege im Basisverzeichnis der Dateiverwaltung des Kunden (also auf oberster Ebene) den Ordner '''''backup_estugo''''' an.
::Lege im Basisverzeichnis der Dateiverwaltung des Kunden (also auf oberster Ebene) den Ordner '''''backup_*datum*''''' an.
 
==Zwischeninfo an den Kunden==
 
:;Vorlage im OTRS -> "Backup wiederherstellen"
 
::-> Informiere den Kunden über den Status
::-> ersetze Anrede und ggf. Ordnernamen
::-> lasse das Ticket offen


== Wiederherstellung aus Backup in der Shell==
== Wiederherstellung aus Backup in der Shell==
Zeile 66: Zeile 53:
:;Am Besten wird es sein, Du startest das Backup in einer [[Screen-Session]]
:;Am Besten wird es sein, Du startest das Backup in einer [[Screen-Session]]
::Nutze hierzu folgenden Befehl: <code>screen</code>
::Nutze hierzu folgenden Befehl: <code>screen</code>
::Die Wiederherstellung läuft dann auch im Hintergrund weiter falls Du aus irgend einem Grund selbst aus der SSH Session "fliegst"
   
   
:;Die Daten aus dem Backup sind nach wie vor auf dem Container zu finden im Ordner /mnt
:;Die Daten aus dem Backup sind durch das Mounten auf dem Container eingehängt und zu finden im Ordner /mnt
::auf z.B. www71.estugo.de via SSH anmelden dann entsprechendes aus dem Ordner /mnt in den Ordner backup_estugo KOPIEREN
::auf z.B. www71.estugo.de via SSH anmelden dann entsprechendes aus dem Ordner /mnt in den Ordner backup_estugo KOPIEREN
::Passe im folgenden Befehl einfach den kompletten Ordnerpfad im ersten Teil an, im zweiten Teil nur den Namen der Subdomain.
::Passe im folgenden Befehl einfach den kompletten Ordnerpfad im ersten Teil an, im zweiten Teil nur den Namen der Subdomain.
Zeile 105: Zeile 93:
==Bonus_DB==
==Bonus_DB==


:; Datenbank direkt Dumpen aus /mnt/var/lib/mysql/datenbank_gx1
:; Datenbank direkt Dumpen aus z.B. /mnt/var/lib/mysql und hierin die DB web147_Wordpress
 
::Socket für MySQL auf Port 3333 öffnen mit dem /mnt Pfad als Datadir
:: <code>mysqld --datadir=/mnt/var/lib/mysql --user=mysql --port=3333 --socket=/tmp/mysqlmc.sock</code>
 
::Dump erstellen
::<code>mysqldump -uadmin -p$(cat /etc/psa/.psa.shadow) --protocol=socket --socket=/tmp/mysqlmc.sock web147_Wordpress >/root/web147_Wordpress.sql</code>


::Folgenden Befehl habe ich für den Dump verwendet
::Socket wieder schließen
:: <code>mysqldump -f -p`cat /etc/psa/.psa.shadow ` --socket=/tmp/mysqlmc.sock -uadmin ##datenbank_name## > /root/####datenbank_name###_###datum###.sql.dump</code>
::<code>mysql -uadmin -p$(cat /etc/psa/.psa.shadow) --protocol=socket --socket=/tmp/mysqlmc.sock --execute "shutdown;"</code>
::Anschliessend habe ich den dump als "tar.gz" via
:: <code>tar -cvzf /var/www/vhosts/######.#####.hostkraft.de/####datenbank_name###_###datum###.sql.dump.tar.gz /root/datenbank_name_17122019.sql.dump</code>
:: generiert und wieder hinter mir aufgeräumt.

Aktuelle Version vom 28. März 2025, 16:02 Uhr

Allgemeines

1. Folgende Daten müssen vorliegen oder vom Kunden angefordert werden
-> Server (siehe alternativ ggf. Bahnhof)
-> Domain
-> Datum der Wiederherstellung
-> Ordner der wiederhergestellt werden soll
-> Datenbank die wiederhergestellt werden soll
-> probiere vorab immer nur die Dateien wiederherzustellen, oft reicht dies schon aus (es sei denn der Kd hat definitiv die Datenbank kaputt gemacht, z.B. CSV Import oder Shop-Update)
-> Bei fehlgeschlagen Updates muss immer beides wiederhergestellt werden

Vorbereiten der Wiederherstellung

1. Backup mounten

1.1 Anmeldung im Cloudpit
1.2 Suche mittels Suchfunktion den Container, für welchen du das Backup einspielen möchtest
1.3 Suche dir unter "Datensicherung" das vom Kunden gewünschte Backup raus
1.4 Klicke unter Aktionen auf "Backup mounten"
Achtung!!! Ausschließlich Backup mounten
1.5 Warte bis das Backup gemountet wurde
Das Backup befindet sich nun im Ordner /mnt

2. Ordner backup_*datum* erstellen

Melde Dich als admin im Plesk an
Wechsele in das Abo des Kunden
Lege im Basisverzeichnis der Dateiverwaltung des Kunden (also auf oberster Ebene) den Ordner backup_*datum* an.

Wiederherstellung aus Backup in der Shell

Verbinde dich per Putty auf den Container (z.B. www70.estugo.de)

Melde Dich als User root auf dem Server an

DATENBANK wiederherstellen

Datenbank via Shell aus dem Ordner /mnt in den Ordner /backup_estugo im Kundenabo kopieren und entpacken
Hierzu hast Du als Vorbereitung den Ordner backup_estugo im Basisverzeichnis des Kunden angelegt.
Der folgende Befehl kopiert und entpackt die Datenbank aus /mnt in das Verzeichnis des Kunden: (Achtung Dokumentenstamm und DB-Name anpassen)
cp -a /mnt/var/lib/mysql-gzdumps/XXX_XX.sql.gz /var/www/vhosts/XXX.XXX.hostkraft.de/backup_estugo/ && gunzip /var/www/vhosts/XXX.XXX.hostkraft.de/backup_estugo/XXX_XXX.sql.gz
Im Anschluss Benutzer anpassen
Die Datenbank hat nun den Nutzer "root", damit der Kunde die Datei auch löschen kann, muss der Richtige Nutzer angepasst werden (meist der erste Teil der Subdomain)
chown -R ############:psacln /var/www/vhosts/XXX.XXX.hostkraft.de/backup_estugo/XXX_XXX.sql
Um eine Datenbankbackup aus dem direkten Ordner /mnt/var/lib/mysql zu besorgen zB wenn unser CronJob nicht klappte siehe weiter unten den Punkt Bonus DB

FTP-DATEN wiederherstellen

Am Besten wird es sein, Du startest das Backup in einer Screen-Session
Nutze hierzu folgenden Befehl: screen
Die Wiederherstellung läuft dann auch im Hintergrund weiter falls Du aus irgend einem Grund selbst aus der SSH Session "fliegst"
Die Daten aus dem Backup sind durch das Mounten auf dem Container eingehängt und zu finden im Ordner /mnt
auf z.B. www71.estugo.de via SSH anmelden dann entsprechendes aus dem Ordner /mnt in den Ordner backup_estugo KOPIEREN
Passe im folgenden Befehl einfach den kompletten Ordnerpfad im ersten Teil an, im zweiten Teil nur den Namen der Subdomain.
rsync -arvuP /mnt/var/www/vhosts/XXX.XXX.hostkraft.de/html/gx2 /var/www/vhosts/XXX.XXX.hostkraft.de/backup_estugo/
um ein Backup zu beschleunigen und ggf unwichtige Ordner auszuschließen, hilt der Zusatz --exclude (siehe Beispiel)
rsync -arvuP --exclude=verzeichnis/ /mnt/var/www/vhosts/XXX.XXX.hostkraft.de/html/gx2 /var/www/vhosts/XXX.XXX.hostkraft.de/backup_estugo/

E-MAILS wiederherstellen (nur zur Info)

Daten sind wie gehabt unter dem Ordner /mnt zu finden
- z.B. per midnight commander (mc) den Mailordner des Kunden suchen und mit folgendem Befehl gezielt Dateien aus dem Backup in den Kundenverzeichnis kopieren.
rsync -arvuP /mnt/var/qmail/mailnames/alexa-gmbh.at/office/Maildir/.Sent/cur/ /var/qmail/mailnames/alexa-gmbh.at/office/Maildir/.Sent/cur
Hier ein Beispiel für die Wiederherstellung eines ganzen Postfach´s
rsync -av --delete /mnt/var/qmail/mailnames/tomaske.net/ordner/Maildir /var/qmail/mailnames/tomaske.net/ordner/

Nach der Wiederherstellung

-> Es kann je nach Daten ca. 30-90 Minuten dauern
-> Sobald die Wiederherstellung abgeschlossen ist, informiere den Kunden

Backup in Cloudpit abhängen

Im Cloudpit unter "Datensicherungen" auf Backup unmounten klicken
(Gekenntzeichnet durch den orange farbenen Balken oberhalb der verfügbaren Backups)

Eintrag im Bahnhof

-> Damit wir wissen wer wann Daten wiederhergestellt hat, halte dies in der Datenbank fest
-> Der Text könnte wie folgt lauten
-> ersetze Kürzel, Datum und ggfs. den Text
^mp 18.04.2017:
MySQL wiederhergestellt
Ordner wiederhergestellt

Bonus_DB

Datenbank direkt Dumpen aus z.B. /mnt/var/lib/mysql und hierin die DB web147_Wordpress
Socket für MySQL auf Port 3333 öffnen mit dem /mnt Pfad als Datadir
mysqld --datadir=/mnt/var/lib/mysql --user=mysql --port=3333 --socket=/tmp/mysqlmc.sock
Dump erstellen
mysqldump -uadmin -p$(cat /etc/psa/.psa.shadow) --protocol=socket --socket=/tmp/mysqlmc.sock web147_Wordpress >/root/web147_Wordpress.sql
Socket wieder schließen
mysql -uadmin -p$(cat /etc/psa/.psa.shadow) --protocol=socket --socket=/tmp/mysqlmc.sock --execute "shutdown;"