VPS: Website-Daten manuell sichern und nach Betriebssystem-Neuinstallation importieren
Bitte verwenden sie die "Drucken" Funktion am Seitenende, um ein PDF zu erstellen.
Dieser Artikel unterstützt Sie dabei, Ihre Website-Daten und Datenbanken lokal auf Ihrem Computer zu sichern, bevor Sie ein neues Betriebssystem auf Ihrem IONOS VPS installieren, und diese anschließend wieder zu importieren. Da bei einer Neuinstallation des Betriebssystems alle Daten auf dem Server gelöscht werden, ist dieser Prozess zwingend erforderlich.
In diesem Artikel erfahren Sie, wie Sie:
- erforderliche Website-Daten und Konfigurationsdateien für Apache und Nginx ermitteln.
- die verwendete MySQL-Datenbank exportieren und lokal sichern.
- die Website-Dateien und die exportierte MySQL-Datenbank lokal auf Ihrem Computer speichern.
- nach der Betriebssystem-Neuinstallation die Anwendungen Apache, Nginx, PHP, MySQL wieder installieren.
- die gesicherten Daten und die Datenbank vom lokalen Computer wieder auf den VPS importieren.
Vorsicht
Da Sie das Betriebssystem auf Ihrem bestehenden VPS neu installieren, gehen alle auf dem Server befindlichen Daten unwiderruflich verloren. Stellen Sie sicher, dass Sie alle Sicherungsschritte inklusive des Exports der Datenbank und dem Download der Dateien erfolgreich abgeschlossen haben, bevor Sie die Installation des neuen Betriebssystems im IONOS Cloud Panel starten.
Hinweise
Dieser Vorgang erfordert eine sorgfältige Planung und Durchführung.
Prüfen Sie, welche Sicherheitseinstellungen und -konfigurationen nach der Installation des neuen Betriebssystems vorgenommen werden müssen. Dies gilt sowohl für das installierte Betriebssystem als auch für die installierten Anwendungen.
Stellen Sie sicher, dass die Funktionalität Ihrer Websites, Anwendungen und Skripte sorgfältig geprüft wird. Planen Sie daher für die Tests und für die Behebung von Fehlern genug Zeit ein.
Informieren Sie ggf. Ihre Nutzer über geplante Ausfallzeiten.
Die Sicherung und Migration von Daten liegt in Ihrer Verantwortung und ist nicht Bestandteil des IONOS Supports.
Website-Dateien ermitteln
Bevor Sie das System löschen, müssen Sie die erforderlichen Website-Dateien ermitteln.
Apache
- Stellen Sie eine SSH-Verbindung zu Ihrem VPS her und loggen Sie sich als Administrator ein. Eine Anleitung finden Sie im folgenden Artikel: Per SSH mit dem Linux-Server verbinden
Um in allen Dateien im Verzeichnis /etc/apache2/sites-enabled und dessen Unterverzeichnissen nach Text zu suchen, in dem der Name Ihrer Domain enthalten ist, ersetzen Sie im unten stehenden Befehl den Platzhalter. Geben Sie anschließend den Befehl ein.
[root@localhost ~]# grep -Ril "DOMAINNAME" /etc/apache2/sites-enabled
Beispiel:
[root@localhost ~]# grep -Ril "example.com" /etc/apache2/sites-enabled
Anschließend wird der Dateipfad für die Konfigurationsdatei Ihrer Website angezeigt. Beispiel:
/etc/apache2/sites-enabled/example.com.conf
Öffnen Sie die Datei mit dem Editor vi. Passen Sie hierzu den unten stehenden Befehl an und geben Sie diesen anschließend ein:
[root@localhost ~]# vi /etc/PFAD/DATEINAME.conf
Beispiel:
[root@localhost ~]# vi /etc/apache2/sites-enabled/example.com.conf
Notieren Sie den Pfad zu den Website-Dateien, der in der Zeile DocumentRoot aufgeführt ist. Im unten aufgeführten Beispiel handelt es sich um das Verzeichnis /var/www/html.
[root@localhost ~]# vi /etc/apache2/sites-enabled/example.com.conf
<VirtualHost *:80> … ServerAdmin webmaster@localhost DocumentRoot /var/www/html … ErrorLog ${APACHE LOG DIR}/error.log CustomLog ${APACHE LOG DIR}/access.log combined
- Drücken Sie die Taste [ESC].
- Um vi zu beenden und die Datei zu speichern, geben Sie den Befehl :wq ein und drücken Sie anschließend Enter.
Nginx
- Stellen Sie eine SSH-Verbindung zu Ihrem bisher verwendeten Server her und loggen Sie sich als Administrator ein. Eine Anleitung finden Sie im folgenden Artikel: Per SSH mit dem Linux-Server verbinden
Öffnen Sie das Nginx-Konfigurationsverzeichnis.
[root@localhost ~]# cd /etc/nginx
Öffnen Sie die Hauptkonfigurationsdatei von Nginx mit dem Editor vi. In der Regel handelt es sich um die Datei nginx.conf. Passen Sie hierzu den unten stehenden Befehl an und geben Sie diesen anschließend ein:
[root@localhost ~]# vi /etc/nginx/nginx.conf
- Suchen Sie in der Hauptkonfigurationsdatei nach Zeilen, die include beinhalten. Prüfen Sie anschließend, welche weiteren Konfigurationsdateien oder -verzeichnisse geladen werden (z. B., sites-enabled/*)
- Notieren Sie die benötigten Konfigurationsdateien oder -verzeichnisse und deren Pfade.
Um die root-Direktive zu finden, die den Pfad zu den Website-Dateien angibt, geben Sie den folgenden Befehl ein:
[root@localhost ~]# grep -R 'root' /etc/nginx/
Dieser Befehl durchsucht alle Dateien unterhalb von /etc/nginx nach der Zeichenfolge root. Die Ausgabe zeigt Ihnen die Dateien und die zugehörigen Zeilen an, in denen die root-Direktive gesetzt ist. Die Ausgabe von grep kann mehrere Zeilen enthalten, wenn Nginx z. B. mehrere Websites (Server Blocks) hostet. Jede Zeile zeigt den Pfad der Konfigurationsdatei und die Zeile an, in der die root-Direktive gesetzt ist. Beispiel: etc/nginx/sites-available/example.com: root /var/www/example.com/html;
In diesem Beispiel wird der Pfad /var/www/example.com/html als Wurzelverzeichnis für die Website example.com verwendet.
- Notieren Sie den Pfad des Wurzelverzeichnisses.
Prüfen Sie den Inhalt des Wurzelverzeichnisses. Um den Inhalt anzuzeigen, geben Sie den folgenden Befehl ein:
[root@localhost ~]# ls -l /PFAD
Beispiel:
[root@localhost ~]# ls -l /var/www/example.com/html
MySQL-Datenbank sichern
Um die MySQL-Datenbank für Ihre Website zu sichern, müssen Sie die Zugangsdaten der MySQL-Datenbank kennen. Darüber hinaus benötigen Sie die folgenden Informationen:
- Port
- Host
- Name der Datenbank
Wenn Ihnen die Zugangsdaten der MySQL-Datenbank bekannt sind, können Sie diesen Abschnitt überspringen.
Zugangsdaten ermitteln
Im Folgenden wird erklärt, wo Sie die MySQL-Zugangsdaten finden:
WordPress
In WordPress finden Sie die MySQL-Zugangsdaten in der Datei wp-config.php. Diese befindet sich im Stammverzeichnis Ihrer WordPress-Installation.
Typische Pfade sehen z. B. wie folgt aus:
/var/www/html/wp-config.php
oder
/var/www/example.com/wp-config.php /** The name of the database for WordPress */ define('DB_NAME', 'db123456789');
/** MySQL database username */ define('DB_USER', 'dbo123456789');
/** MySQL database password */ define('DB_PASSWORD', 'Geheimes_Passwort');
/** MySQL hostname */ define('DB_HOST', 'db123456789.hosting-data.io');
/** WordPress Database Table prefix. */$table_prefix = 'abcd_';
Websites ohne CMS
Für Websites, die direkt auf eine Datenbank zugreifen und kein CMS verwenden, hängt die Speicherung der Zugangsdaten von der individuellen Konfiguration ab. Häufig sind die Zugangsdaten in Konfigurationsdateien gespeichert, die von den jeweiligen Skripten verwendet werden. Um in diesem Fall die Zugangsdaten zu finden, müssen Sie in den PHP-, Python-, Java- oder anderen Backend-Dateien nach Datenbankverbindungsparametern suchen.
MySQL-Datenbank exportieren
Um eine MySQL-Datenbank zu sichern, verwenden Sie das Tool mysqldump, das mit den meisten MySQL-Installationen geliefert wird. Ersetzen Sie im unten aufgeführten Befehl die Platzhalter und geben Sie den Befehl anschließend ein.
mysqldump --no-tablespaces --port PORTNUMMER --host=HOSTNAME --user=BENUTZERNAME --password=PASSWORT DATENBANKNAME | gzip > /root/dbdump.sql.gz
Achtung
Wenn Sie das Passwort direkt im Befehl hinter --password= eingeben, wird es im Klartext in der Befehlshistorie (Bash History) Ihres Servers gespeichert. Um dies zu vermeiden, können Sie den Parameter --password ohne Wert angeben. In diesem Fall werden Sie nach dem Absenden des Befehls zur sicheren Passworteingabe aufgefordert, bei der Ihre Eingabe unsichtbar bleibt.
Beispiel:
mysqldump --user=BENUTZERNAME --password DATENBANKNAME > /root/dbdump.sql
Nach der Eingabe des Befehls wird die Datenbank in das Root-Verzeichnis exportiert. Der Dateiname lautet hierbei dbdump.sql.gz.
Hinweis
Wenn Ihre Dateinamen, Passwörter oder Benutzernamen Sonderzeichen enthalten, müssen Sie diese im mysqldump- oder mysql-Befehl in einfache Anführungszeichen (') setzen.
Beispiel: mysqldump […] --password='%gCjmnrmLk!xnSefw'
Website-Dateien und die exportierte MySQL-Datenbank lokal speichern
Speichern Sie die Kopie der Website-Dateien und die exportierte MySQL-Datenbank auf Ihrem lokalen Computer. Dies ist der entscheidende Schritt, bevor Sie die Neuinstallation des Betriebssystems einleiten. Hierfür können Sie das Programm FileZilla verwenden. FileZilla wird für Computer mit Windows-, macOS- und Linux-Betriebssystem angeboten.
Sie können die aktuelle Installationsdatei für Ihr Betriebssystem auf der folgenden Seite herunterladen: https://filezilla-project.org/download.php?type=client
Um mit FileZilla eine Verbindung zu Ihrem Server herzustellen und die Kopie der Website-Dateien sowie die exportierte MySQL-Datenbank auf einen lokalen Computer herunterzuladen, gehen Sie wie folgt vor:
- Starten Sie FileZilla auf Ihrem lokalen Computer.
- Geben Sie im Feld Server die IP-Adresse des Servers ein.
- Geben Sie im Feld Benutzer den Benutzernamen root ein.
- Geben Sie im Feld Passwort das Passwort ein, das Sie festgelegt haben.
- Geben Sie im Feld Port den Port 22 ein.
- Klicken Sie auf Verbinden. Die Verbindung zum Server wird hergestellt. Im Bereich links werden die Verzeichnisse angezeigt, die sich auf Ihrem Client befinden. Im Bereich rechts werden die Verzeichnisse angezeigt, die sich auf Ihrem Server befinden.
- Erstellen Sie ein Verzeichnis auf Ihrem lokalen Computer.
- Öffnen Sie das Wurzelverzeichnis Ihres Webservers.
- Markieren Sie auf Ihrem Server das Wurzelverzeichnis und kopieren Sie dieses anschließend mittels Drag-and-drop in das gewünschte Verzeichnis, das sich auf Ihrem lokalen Computer befindet.
- Kopieren Sie zusätzlich die benötigten Konfigurationsdateien oder -verzeichnisse mittels Drag-and-drop in das gewünschte Verzeichnis, das sich auf Ihrem lokalen Computer befindet.
- Öffnen Sie das Root-Verzeichnis.
- Markieren Sie die exportierte Datenbank. Der Dateiname lautet dbdump.sql.gz. Kopieren Sie die Datei anschließend mittels Drag-and-drop in das gewünschte Verzeichnis, das sich auf Ihrem lokalen Computer befindet.
Neuinstallation des Betriebssystems
Führen Sie die Neuinstallation des Betriebssystems über Ihr IONOS Cloud Panel durch.
Achtung
Hierbei werden alle Daten auf dem VPS gelöscht.
Eine Anleitung, wie Sie ein neues Image installieren, finden Sie im folgenden Artikel: Image neu installieren (VPS)
Anwendungen auf dem neuen Server installieren
Nachdem das neue Betriebssystem installiert ist, müssen Sie die Umgebung neu aufbauen. Zu diesem Zweck müssen Sie auf Ihrem neuen Server die benötigten Anwendungen installieren.
Achtung
Prüfen Sie vor der Installation die erforderlichen Systemvoraussetzungen. Informieren Sie sich darüber hinaus auf den Seiten der Softwarehersteller über eventuelle Kompatibilitätsprobleme.
Apache, MySQL/MariaDB und PHP installieren
Eine Anleitung, wie Sie Apache, MySQL/MariaDB und PHP installieren, finden Sie in den folgenden Artikeln:
LAMP-Stack auf einem Server installieren (AlmaLinux 9 und Rocky Linux 9)
LAMP-Stack auf einem Server mit Debian oder Ubuntu installieren
Nginx installieren
Eine Anleitung, wie Sie Nginx installieren, ist im folgenden Artikel aufgeführt:
Plesk installieren
Eine Anleitung, wie Sie Plesk installieren, finden Sie in den folgenden Artikeln:
Plesk installieren (VPS Linux und migrierte Cloud Server)
Plesk installieren (VPS Windows und migrierte Cloud Server)
WordPress installieren
Eine Anleitung, wie Sie WordPress auf einem Server installieren, finden Sie in der WordPress Dokumentation. Diese finden Sie auf der folgenden Seite:
Betriebssystem und Anwendung absichern
Passen Sie nach der Installation des neuen Betriebssystems alle erforderlichen Sicherheitseinstellungen und -konfigurationen des Servers an. Dies gilt sowohl für das neue Betriebssystem als auch für die installierten Anwendungen.
Informationen zu einigen grundsätzlich wichtigen Sicherheitsmaßnahmen finden Sie im folgenden Artikel: Wichtige Sicherheitsinformationen für Ihren Linux-Server (Teil 2 von 2)
Website-Dateien importieren
Apache
- Stellen Sie eine SSH-Verbindung zu Ihrem neuen Server her und loggen Sie sich als Administrator ein.
- Öffnen Sie zusätzlich FileZilla.
- Kopieren Sie die gesicherten Daten und Konfigurationsdateien mit FileZilla mittels Drag-and-drop in die entsprechenden Verzeichnisse auf Ihrem neuen Server.
- Prüfen Sie die Konfigurationsdateien sowie die Pfade und Einstellungen, die spezifisch auf die alte Serverumgebung ausgerichtet waren, und passen Sie diese ggf. an.
Um Apache neu zu starten, wechseln Sie zum Programm, mit dem Sie die SSH-Verbindung hergestellt haben und geben Sie den folgenden Befehl ein:
AlmaLinux und Rocky Linux
[root@localhost ~]# ssudo systemctl restart httpd
Debian und Ubuntu
[root@localhost ~]# sudo systemctl restart apache2
- Prüfen Sie die von Ihnen verwendeten Skripte und passen Sie diese ggf. an.
- Testen Sie die Website und die Konfiguration.
Nginx
Stellen Sie eine SSH-Verbindung zu Ihrem neuen Server her und loggen Sie sich als Administrator ein.
Öffnen Sie zusätzlich FileZilla.
Kopieren Sie die gesicherten Daten und Konfigurationsdateien mit FileZilla mittels Drag-and-drop in die entsprechenden Verzeichnisse auf Ihrem neuen Server.
Prüfen Sie die Konfigurationsdateien sowie die Pfade und Einstellungen, die auf die alte Serverumgebung ausgerichtet waren und passen Sie diese ggf. an.
Um Nginx neu zu starten, wechseln Sie zum Programm, mit dem Sie die SSH-Verbindung hergestellt haben und geben Sie den folgenden Befehl ein:
[root@localhost ~]# sudo systemctl restart nginx
Prüfen Sie die von Ihnen verwendeten Skripte und passen Sie diese ggf. an.
Testen Sie die Website und die Konfiguration.
MySQL-Datenbank importieren
- Öffnen Sie FileZilla.
- Kopieren Sie die exportierte Datenbank mittels Drag-and-drop in das entsprechende Verzeichnis auf Ihrem neuen Server.
- Wechseln Sie zum Programm, mit dem Sie die SSH-Verbindung hergestellt haben.
- Öffnen Sie das Verzeichnis, in dem sich die exportierte Datenbank befindet.
Um Ihre Daten wiederherzustellen, führen Sie den Befehl mysql nach dem unten aufgeführten Schema aus. Ersetzen Sie hierbei die in Großbuchstaben geschriebenen Platzhalter durch die Zugangsdaten der Datenbank, in der Sie die Daten wiederherstellen möchten.
[root@localhost ~]# gunzip -c DATEINAME | mysql --user=BENUTZERNAME --password=PASSWORT DATENBANK
- Prüfen Sie die Sicherheitseinstellungen Ihrer MySQL-Datenbank.
WordPress-Blog umziehen
Eine Anleitung, wie Sie Ihren gesicherten WordPress-Blog importieren können, finden Sie auf der folgenden Seite:
Abschluss und Prüfung
DNS-Einstellungen: Da sich die IP-Adresse Ihres VPS bei einer Neuinstallation in der Regel nicht ändert, müssen Sie am DNS nichts anpassen.
Funktionstest: Prüfen Sie die Website auf Skriptfehler und Datenbankverbindungen.
Sicherheit: Passen Sie die Firewall-Regeln und Sicherheitseinstellungen Ihres neuen Betriebssystems sofort an.
Inhalt
- Website-Dateien ermitteln
- MySQL-Datenbank sichern
- MySQL-Datenbank exportieren
- Website-Dateien und die exportierte MySQL-Datenbank lokal speichern
- Neuinstallation des Betriebssystems
- Anwendungen auf dem neuen Server installieren
- Apache, MySQL/MariaDB und PHP installieren
- Betriebssystem und Anwendung absichern
- Website-Dateien importieren
- WordPress-Blog umziehen
- Abschluss und Prüfung
- Nach oben