Auch Datenbanken gehören ins Backup. Um ein Backup einer Datenbanken anzulegen empfiehlt sich mysqldump. Es gibt auch die Möglichkeit ein Backup mit phpmyadmin oder ähnlichen Frontends anzufertigen. Allerdings sind diese oft nicht installiert und bei umfangreichen Datenbanken stößt man schnell an Einschränkungen wie z.B PHP-Timeouts.
Mysql/MariaDB bringt bei der Installation schon die nötigen Backup-Tools mit. Daher müssen diese nicht extra installiert werden.
mysqldump Backup und Restore
Mysqldump ist ein Tool für die Kommandozeile. Der Aufrufe gestaltet sich immer nach dem gleichen Schema.
mysqldump -u<username> -p<passwort> <datenbankname> > <dateiname.sql>
Um die erzeugten Dumpfiles wieder in den Datenbankserver einzuspielen übergeben wir den Inhalt des Dumpfiles dem MySQL-Server.
cat dateiname.sql | mysql mysqldump -u<username> -p<passwort> <datenbankname>
Um das Dumpfile beim Erzeugen des Dumps gleichzeitig zu komprimieren kann dies mit gzip erfolgen.
mysqldump -u<username> -p<passwort> <datenbankname> | gzip -c > <dateiname.sql.gz>
Beim Restoren des Dumps muss dann der Befehl cat durch zcat erstetzt werden, da zcat in der Lage ist gezippte Dateien anzuzeigen.
zcat dateiname.sql | mysql mysqldump -u<username> -p<passwort> <datenbankname>
Es gibt noch eine Vielzahl von optionalen Parametern die unter gewissen Umständen beim erstellen des Dumfiles erforderlich sein können. Diese und weitere Informationen können in der Dokumentation zu mysqldump nachgelesen werden.