Haben Sie Fragen? Senden Sie uns doch eine Nachricht

OneSystems GmbH

OneSystems GmbH

System Management aus der Schweiz

+41 44 586 40 18
Email: info@onesystems.ch

OneSystems GmbH
Grindlenstrasse 9, 9630 Wattwil, Schweiz

Open in Google Maps
  • Home
  • Dienstleistungen
    • Web Hosting
    • E-Mail Hosting
    • Ihre eigene Daten Cloud
  • Blog
  • Hilfe & Support
    • Remote Support
  • Kontakt
  • Home
  • Blog
  • Docker
  • Migration von Datenbanken in Docker: So gelingt das Upgrade sicher und sauber
13. Januar 2026

Migration von Datenbanken in Docker: So gelingt das Upgrade sicher und sauber

Migration von Datenbanken in Docker: So gelingt das Upgrade sicher und sauber

by Michael Kleger / Donnerstag, 01 Mai 2025 / Published in Docker, Migration

Datenbank-Upgrades gehören zu den Aufgaben, die man selten gern anfasst – vor allem, wenn produktive Systeme davon abhängen. Doch spätestens wenn eine Anwendung wie z.B. Authentik ein bestimmtes Datenbank-Mindestlevel verlangt (z. B. PostgreSQL ≥ 13), führt kein Weg an einer Migration vorbei.

In diesem Artikel zeige ich praxisnah, wie du eine bestehende MariaDB- oder PostgreSQL-Datenbank in einem Docker-Setup sicher auf eine neue Version migrierst.

Ob du eine produktive Authentik-Instanz migrierst oder deine Datenbank einfach sauber aktualisieren willst: Diese Anleitung führt dich Schritt für Schritt durch den Prozess.

    1. Alle Container ausser der Datenbank stoppen damit nichts mehr an den Daten in der Datenbank verändert wird
    2. Ein Backup der Datenbank ausführen
      1. Container ID herausfinden
        docker ps | grep "db"
      2. Dump ausführen
        1. PostgreSQL
          docker exec <container-id> pg_dumpall -U pg-user > pg-old.sql
        2. MariaDB
          docker exec <container-id> bash -c 'mysqldump -u mariadb-user -p mariadb-db' > mariadb-old.sql
      3. Wenn die Datenbank direkt auf ein im Dateisystem bestehenden Ordner schreibt muss der „neu“ angelegt werden und damit bei einem fehler wieder auf den „alten“ stand zurückgegriffen werden kann.
        mv database database.bak
        mkdir database
    3. Docker Container DB stoppen und in die Compose Datei bearbeiten
      1. Neues Image hinzufügen
      2. alle anderen Container Kommentieren mit einem # damit die aktuell noch nicht gestartet werden
      3. Stack starten
        docker compose up -d
      4. Neue Container ID herausfinden
        docker ps | grep "db"
      5. Container Log prüfen ob keine Fehler oder Warnungen aufgetaucht sind und der Container läuft
        docker logs <container-id>
      6. Dump wieder importieren
        1. PostgreSQL
          cat pg-old.sql | docker exec -i <container-id> psql -U postgres
        2. MariaDB
          cat mariadb-old.sql | docker exec -i <container-id> bash -c 'mariadb -u mariadb-user -p'
      7. Bei mir gab es nach dem Importieren Berechtigungsproblem, daher gleich nach dem importieren die Berechtigungen neu setzen
        1. PostgreSQL
          docker exec -it <container-id> psql -U pg-user
          GRANT ALL PRIVILEGES ON DATABASE pg-user TO pg-db;
          
        2. MariaDB
          docker exec -it <container-id> bash -c 'mariadb -u mariadb-user -p mariadb-db'
          GRANT ALL PRIVILEGES ON mariadb-db.* TO 'mariadb-user'@'%';
    4. Alle Container wieder normal starten
      1. Alles wieder stoppen
        docker compose down
      2. Alle Kommentierten # Container in der Compose Datei wieder auskommentieren
      3. Alles starten
        docker compose up -d

 

Evtl. muss je nach Umgebung der komplette Stack nochmals neugestartet werden da noch Tabellen oder Schema Updates durchgeführt wurden mit der neuen Datenbank Version.

  • Tweet
Tagged under: Docker, MariaDB, Migration, PostgreSQL

About Michael Kleger

What you can read next

Docker Desktop unter Ubuntu installieren
Einen eigenen Identitätsanbieter betreiben (Teil 2)
Einen eigenen Identitätsanbieter betreiben (Teil 1)

Schreibe einen Kommentar Antwort abbrechen

Deine E-Mail-Adresse wird nicht veröffentlicht. Erforderliche Felder sind mit * markiert

Diese Website verwendet Akismet, um Spam zu reduzieren. Erfahre, wie deine Kommentardaten verarbeitet werden.

Letzten Beiträge

  • Der GNOME-Login ist weg – so bringst du ihn zurück

    Nach einem Update oder Neustart kann es passier...
  • Wie die Remmina Verbindungen in Tabs statt in neuen Fenstern öffnen

    Wer regelmässig mit Remmina arbeitet, kennt das...
  • Dateien mit Sonderzeichen sicher löschen

    Beim Arbeiten auf Linux-Servern kann es vorkomm...
  • Automatisierte Backups mit Docker, Cron, Nextcloud Talk & E-Mail

    In diesem Beitrag zeige ich, wie man mit einem ...
  • Windows Server 2025 bereinigen

    Wenn man den Windows Server 2025 (sowie auch äl...

Neueste Kommentare

  • Michael Kleger bei Festplatte einer Virtuellen Maschine verkleinern
  • Harald Strauch bei Festplatte einer Virtuellen Maschine verkleinern
  • Michael Kleger bei Mac OS X 10.11El Capitan‎: ISO für Installation erstellen
  • Danyel Gloser bei Mac OS X 10.11El Capitan‎: ISO für Installation erstellen
  • Wie kann man unter Ubuntu den Bildschirm teilen? - OneSystems GmbH bei Flatpack unter Ubuntu installieren

Categories

  • b1gMail
  • CentOS
  • Debian
  • Docker
  • Identitätsanbieter
  • Linux
  • Mac OSX
  • Microsoft Exchange
  • Microsoft Outlook
  • Migration
  • Mint
  • Monitoring
  • Neuigkeiten
  • Nextcloud
  • PowerShell
  • Python
  • Raspberry Pi
  • Sicherheit
  • Tipps und Tricks
  • Ubuntu
  • VMware
  • Webseiten
  • Webserver
  • Windows
  • Windows zu Linux

Die OneSystems GmbH mit Sitz in Wattwil ist ein unabhängiger IT-Dienstleister für die Planung, Umsetzung und den Betrieb moderner IT-Infrastrukturen, Weblösungen und individueller Software. Wir begleiten Unternehmen ganzheitlich von der Konzeption bis zum laufenden Betrieb und übernehmen dabei sowohl technische Verantwortung als auch den langfristigen Support.

Unsere Kunden stammen aus der Schweiz, Deutschland und Österreich und vertrauen auf Lösungen, die stabil, sicher und nachvollziehbar aufgebaut sind. Statt kurzlebiger Trends setzen wir auf saubere Architektur, etablierte Standards und nachhaltige Qualität, damit Systeme nicht nur heute funktionieren, sondern auch morgen noch beherrschbar bleiben.

Letzten Blog Posts

  • Der GNOME-Login ist weg – so bringst du ihn zurück

  • Wie die Remmina Verbindungen in Tabs statt in neuen Fenstern öffnen

  • Dateien mit Sonderzeichen sicher löschen

Kontakt

Email: Kontaktformular

OneSystems GmbH
Grindlenstrasse 9
9630 Wattwil
Schweiz

Copyright © 2018-2026 OneSystems GmbH, Alle Rechte vorbehalten.
Impressum | Datenschutzerklärung | AGBs | Kontakt

TOP