Dies ist ein erster Entwurf und noch nicht als fertige Anleitung zu verstehen.
Unter eisfair ist es möglich, verschiedene Versionslinien der Datenbanksysteme mysql und mariadb parallel zu installieren und zu betreiben. Derzeit sind dies folgende eisfair-Pakete:
- mysql4112: MySQL 4.1.12
- mysql5173: MySQL 5.1.73
- mariadb55: MariaDB: 5.5.x
- mariadb100: MariaDB 10.0.x
- mariadb102: MariaDB 10.2.x
- mariadbdb103: MariaDB 10.3.x
Upgrades werden nur innerhalb einer Versionslinie vorgenommen, so dass eine Umstieg auf eine andere Versionslinie manuell vorzunehmen ist, was hier im folgenden an einem Beispiel beschrieben werden soll.
Alle installierten Datenbanksysteme nutzen die gleiche Passwortdatei /etc/.my.cnf, in der die für automatische Vorgänge notwendigen Passwörter des Datenbank-Root-Users niedergelegt sind. Diese gelten also für sämtliche Datenbankversionen gleichzeitig.
Jede Versionslinie der Datenbanksysteme besitzen jedoch eigene systemweite Konfigurationsdatei, Socket, Datenbankverzeichnis und Datenbankbackupverzeichnis:
Datenbank | Konfigurationsdatei | Socket | Datenbankverzeichnis (konfigurierbar) | Datenbankbackupverzeichnis (konfigurierbar) |
---|---|---|---|---|
mysql4112 | /etc/mysql/my4112.cnf | /run/mysql/4112/mysql.sock | /srv/mysql/4112 | /srv/mysql_backup/4112 |
mysql5173 | /etc/mysql/my5173.cnf | /run/mysql/5173/mysql.sock | /srv/mysql/5173 | /srv/mysql_backup/5173 |
mariadb55 | /etc/mysql/my55.cnf | /run/mysql/55/mysql.sock | /srv/mysql/55 | /srv/mysql_backup/55 |
mariadb100 | /etc/mysql/my100.cnf | /run/mysql/100/mysql.sock | /srv/mysql/100 | /srv/mysql_backup/100 |
mariadb102 | /etc/mysql/my102.cnf | /run/mysql/102/mysql.sock | /srv/mysql/102 | /srv/mysql_backup/102 |
mariadb103 | /etc/mysql/my103.cnf | /run/mysql/103/mysql.sock | /srv/mysql/103 | /srv/mysql_backup/103 |
Die Links /etc/my.cnf und /run/mysql/mysql.sock zeigen jeweils auf die Standard-Datenbankversion, also diejenige, auf die ohne zusätzliche Parameter mit Datenbankprogrammen zugegriffen werden kann, z. B.:
# ls -l /etc/my.cnf lrwxrwxrwx 1 root root 15 Mar 8 11:12 /etc/my.cnf -> mysql/my102.cnf # ls -l /run/mysql/mysql.sock lrwxrwxrwx 1 root root 14 Mar 8 11:12 /run/mysql/mysql.sock -> 102/mysql.sock
Hier wäre also mariadb102 das Standard-Mariadb/MySQL-Datenbanksystem.
Jede der installierten Versionslinien muss einen eigenen Port zugeordnet haben, der in der jeweiligen Paketkonfiguration festgelegt wird. Die auf dem Port 3306 laufende Datenbankversion ist das Standard-Datenbanksystem.
Nun soll im folgenden ein mariadb102-Datenbanksystem mit den Grundeinstellungen
- Port: 3306
- Socket: /run/mysql/102/mysql.sock
- Konfigurationsdatei: /etc/mysql/my102.cnf
- Datenbankverzeichnis: /srv/mysql/102
- Datenbankbackupverzeichnis: /srv/mysql_backup/102
auf mariadb103 upgedatet und alle Datenbanken aus mariadb102 importiert werden. Soll von einer anderen Ausgangsversion oder auf eine andere Zielversion upgegradet werden, sind die angegebenen Versionsnummer entsprechend anzupassen.
Stoppen aller Pakete, die mariadb102-Datenbanken nutzen
Nun sind alle lokalen Prozesse wie z. B. owncloud, nextcloud oder ein Webserver, die lokal auf die Datenbanken zugreifen, bis zum Abschluss der Arbeiten zu beenden. Dies geschieht durch "Abschalten" dieser Pakete in deren Konfiguration. Externe Clients dürfen nun auch nicht mehr auf die Datenbanken zugreifen.
Installation und Konfiguration von mariadb103
Nach der Installation von mariadb103 ist zunächst dieses neue Datenbanksystem zu konfigurieren, wobei insbesondere ein von 3306 abweichender Port anzugeben ist, z. B. 3307. Nach Abschluss der Konfiguration wird nun dieses neue Datenbanksystem eingerichtet, währenddessen man gefragt wird, ob man das Passwort für den Root-Admin festlegen möchte; dies ist zu bejahen. Das nun eingegebene Passwort wird in allen installierten mariadb/mysql-Datenbanksystem gleichermaßen eingetragen. Die Grundeinstellungen des mariadb103-Datenbanksystems sind somit:
- Port: 3307
- Socket: /run/mysql/103/mysql.sock
- Konfigurationsdatei: /etc/mysql/my103.cnf
- Datenbankverzeichnis: /srv/mysql/103
- Datenbankbackupverzeichnis: /srv/mysql_backup/103
Bis auf
MARIADB103_CONNECT_PORT='3307' # MARIADB103 remote port default=3306 # connect port is also uniq indentifier MARIADB103_DATADIR='/srv/mysql/103' # empty: default /srv/mysql/103 or datadir MARIADB103_BACKUP_TARGET='/srv/mysql_backup/103' # backup target directory
können die weiteren Einstellungen für mariadb103 aus der mariadb102-Konfiguration (manuell) übernommen werden.
Datenbanksystem mariadb102 stoppen und Datenbankbackups erstellen
Nun stoppen wir das mariadb102-Datenbanksystem
# /etc/init.d/mariadb102 stop
und erstellen über den Menüpunkt Administration of services|Database server administration|MariaDB 10.2 server administration|MariaDB Tools|Backup database für alle vorhandenen Datenbanken, also auch der systeminternen Datenbank mysql, ein aktuelles Backup.
Kopieren/Importieren der Datenbankbackups in das neue Datenbanksystem
Zunächst sind die Datenbankbackups vom alten in das neue Backupverzeichnis zu kopieren:
# cp -a /srv/mysql_backup/102 /srv/mysql_backup/103
Über den Menüpunkt Administration of services|Database server administration|MariaDB 10.3 server administration|MariaDB Tools|Restore database importieren wir nun die eben erstellten Datenbankbackups in die neue Datenbankversion und führen nun noch ein Skript zur Durchführung von notwendigen Anpassungen der Datenbanken an die neue mariadb/mysql-Version aus:
# /var/install/bin/mysql-common-tools-update-db --project mariadb103
mariadb103 als neues Standard-Datenbanksystem setzen
Um mariadb103 als neues Standard-datenbanksystem zu setzen, muss dieses noch auf den Port 3306 umgesetzt werden, nachdem vorher mariadb102 auf einen anderen freien Port umgestellt wurde:
- Aufruf der Konfiguration von mariadb102 und Setzen des Ports auf 3308
- Aufruf der Konfiguration von mariadb103 und Setzen des Ports auf 3306
Hiermit erhält mariadb103 folgende Grundeinstellungen
- Port: 3306
- Socket: /run/mysql/103/mysql.sock
- Konfigurationsdatei: /etc/mysql/my103.cnf
- Datenbankverzeichnis: /srv/mysql/103
- Datenbankbackupverzeichnis: /srv/mysql_backup/103
und auch der Link /run/mysql/mysql.sock zeigt auf diese neue Datenbankversion.
Anpassungen an anderen Paketen
Ist in anderen Paketen z. B. nextcloud, owncloud, phpmyadmin, apache2_php7, ... /run/mysql/102/mysql.sock als Socket eingetragen, ist dies nun auf /run/mysql/103/mysql.sock zu ändern. Falls der Link auf das Standard-Datenbanksystem /run/mysql/mysql.sock eingetragen ist, kann das in der Regel so bleiben, da dieser nun auf mariadb103 zeigt.
Mit folgendem Befehl können Pakete ermittelt werden, in deren Konfiguration der Socket der alten Datenbankversion gesetzt wurde:
# grep "/run/mysql/102/mysql.sock" /etc/config.d/*
Eventuell sind solche Korrekturen auch an eigenen oder manuell installierten Programmen oder Skripten erforderlich.
Neustarten vorab gestoppter Pakete
Die zu Beginn der Umstellung gestoppten Pakete wie nextcloud, owncloud oder ein Webserver können nun wieder gestartet werden. Auch externe Clients dürfen nun wieder das Datenbanksystem nutzen.
Deinstallieren des alten Datenbanksystem mariadb102
Nach eine Testphase kann das alte Datenbanksystem mariadb102 samt Daten und Konfiguration über das "Package administration"-Menü deinstalliert werden.