Die Migration einer Oracle-Datenbank in die Oracle Cloud Infrastructure ist eine komplexe Herausforderung, die sorgfältige Planung und präzises Vorgehen erfordert. In diesem Blogbeitrag wird anhand von grafischen Darstellungen erläutert, wie eine physische Online-Migration mit Zero Downtime Migration durchgeführt wird, ohne die Verfügbarkeit der Datenbank zu gefährden. Anschließend wird der Befehl zur Datenbankmigration vorgestellt und dessen Funktionsweise erklärt.
Die Abbildung 1 zeigt die ersten Schritte, die zu Beginn des Migrationsprozesses stattfinden. Es wird davon ausgegangen, dass die Quelldatenbank die primäre Datenbank ist, auf die die Nutzeranwendungen zugreifen. Diese Datenbank wird auf einem lokalen Server im Rechenzentrum des Kunden betrieben. Die Zieldatenbank hingegen wird in der Cloud-Umgebung von Oracle gehostet und als OCI-Zieldatenbank-Service bezeichnet.
Ein wichtiger Schritt im Rahmen dieser Migration ist das Herunterladen und Installieren des ZDM-Tools auf einem Host-System. An dieser Stelle ist es wichtig, bestimmte Voraussetzungen zu beachten:
- Es wird dringend empfohlen, für die Installation der ZDM-Software einen separaten Host zu verwenden.
- Dieser Host muss mindestens über 100 GB freien Speicherplatz verfügen.
- Es muss eine Verbindung zum Quell- und Zieldatenbank-Server gewährleistet sein.
- Der Host für den Zero Downtime Migration Service lässt sich ausschließlich auf den folgenden Betriebssystemen konfigurieren: Oracle Linux 7 (x86-64), Oracle Linux 8 (64-Bit) auf x86-64 und Red Hat Enterprise Linux 8 (64-Bit) auf x86-64.
Die Abbildung 2 präsentiert die nachfolgende Phase der physischen Online-Migration. Nachdem die Backups der Quelldatenbank erstellt wurden, werden die übertragenen RMAN-Backups von ZDM genutzt, um eine Standby-Datenbank in der OCI zu erstellen. Diese ist TDE aktiviert, wodurch sichergestellt wird, dass die Daten während des Transfers und in der Cloud verschlüsselt bleiben. Die RMAN Backups werden aus dem Object Storage wiederhergestellt und zur Initialisierung der Standby-Datenbank verwendet. Die initialisierte Standby-Datenbank ist zunächst nicht synchron mit der Quelldatenbank, da sie auf Basis der erstellten Backups initialisiert wurde. Es besteht keine direkte Verbindung zwischen der Primärdatenbank und der Standby-Datenbank, was bedeutet, dass sie asynchron sind und erst nachträglich synchronisiert werden müssen. Die Synchronisation der Primär- und Standby-Datenbanken, die durch ZDM durchgeführt wird, erfolgt mithilfe von Oracle Data Guard. Data Guard sorgt dafür, dass jede Änderung an der Primärdatenbank in Echtzeit oder nahezu in Echtzeit auch auf die Standby-Datenbank angewendet wird.
Der Migrationsprozess durchläuft verschiedene Phasen, beginnend mit der Durchführung von Vorüberprüfungen auf der Quell- und Zieldatenbank und abschließend mit der Durchführung der Aufräumarbeiten nach der Migration auf der Quell- und Zieldatenbank.
Nach der Einrichtung der Zero-Downtime-Migrationsmodule auf dem Zielserver ist es jederzeit möglich, die Migration anzuhalten. Bei einer physischen Online-Migration wird empfohlen, die Migration nach der Phase ZDM_CONFIGURE_DG_SRC
zu pausieren. Nach Abschluss dieser Phase wird eine Standby-Datenbank auf dem Zielsystem erstellt und die Synchronisation zwischen Quell- und Zieldatenbank erfolgt. Während die Migration pausiert ist, besteht die Möglichkeit, ein Failover zur Cloud-Datenbank durchzuführen, ohne Änderungen an der On-Premises-Datenbank vorzunehmen.
Dies ermöglicht das Testen der neuen Umgebung und das Sicherstellen, dass die Zieldatenbank ordnungsgemäß funktioniert, bevor der endgültige Switchover durchgeführt wird. Des Weiteren besteht die Möglichkeit, während dieser Zeit ein Anwendungsswitchover zur Cloud durchzuführen. Dies impliziert, dass die Anwendung zur Nutzung der neuen Zieldatenbank in der Cloud umgeschaltet wird, während die Migration temporär ausgesetzt ist. Dadurch wird ein reibungsloser Übergang gewährleistet, ohne dass die Anwendung eine längere Ausfallzeit erfährt.
In der finalen Phase der physischen Online-Migration, wie in Abbildung 3 dargestellt, erfolgt der Switchover und der Rollentausch der Datenbanken. Im Rahmen des Switchovers erfolgt eine Umschaltung der Anwendung zur Zieldatenbank in der OCI durch ZDM. Simultan findet ein Rollenwechsel der Primär- und Standby-Datenbanken statt: Die Standby-Datenbank in OCI übernimmt die Funktion der neuen Primärdatenbank, während die ursprüngliche Primärdatenbank zur Standby-Datenbank wird. Dies gewährleistet, dass die Datenbankmigration erfolgreich abgeschlossen ist und die Anwendungen ohne Unterbrechung mit der neuen Primärdatenbank arbeiten können.
Im Normalfall übernimmt somit ZDM das Switchover. Alternativ besteht die Möglichkeit, dass ZDM den Oracle Data Guard Broker einsetzt, um das Switchover zu verwalten. Damit der Broker das Switchover verwaltet, muss eine bidirektionale Netzwerkverbindung über SQLNet zwischen den beteiligten Datenbanken vorhanden sein. Zudem ist zu beachten, dass Broker-Konfigurationen nicht für Oracle Database 11.2.0.4 unterstützt werden.
Nach dem Rollentausch führt ZDM Nach-Migrations-Validierungen durch. Diese Validierungen umfassen die Überprüfung der Zieldatenbank, das Abschließen der Data Guard-Konfiguration, das Ausführen von Datapatch und die Überprüfung der erfolgreichen Migration.
Sowohl die physische Online-Migration als auch andere Migrationsmethoden erfordern eine Vorbereitung der Quell- und Zieldatenbank für die Migration. Die Datenbanken müssen verschiedene Voraussetzungen erfüllen, damit eine Migration überhaupt realisierbar ist. Welche Voraussetzungen erfüllt sein müssen und wie man die Systeme am besten für die physische Online-Migration vorbereitet, ist auf der Oracle-Dokumentationsseite zu finden.
Wenn die Quell- und Zieldatenbanken vorbereitet sind, alle Voraussetzungen für die Migration erfüllen und der ZDM-Host korrekt konfiguriert und aktiv ist, kann die Datenbankmigration gestartet werden. Der folgende Befehl führt zunächst eine Evaluierung der Datenbankmigration durch, bei der die Quelldatenbank ORCL von zdm-sourcecdb auf den Zielknoten zdm-target-db migriert wird. Dabei wird überprüft, ob alle notwendigen Authentifizierungen, Schlüssel, sudo-Befehle und Verzeichnisse korrekt eingerichtet sind. Die tatsächliche Migration wird nicht durchgeführt, sondern nur die Konfigurationsschritte evaluiert, um sicherzustellen, dass alles bereit ist. Die Ausgabe zeigt, dass alle Pre-Check-Schritte mit dem Status PRECHECK_PASSED erfolgreich bestanden wurden, was bestätigt, dass die Umgebung bereit für die Migration ist.
Im nächsten Schritt kann die tatsächliche Migration gestartet werden. Hierzu wird derselbe Befehl wie im obigen Beispiel verwendet, allerdings ohne den Parameter -eval, da dieser nur für die Evaluierung genutzt wurde. Dieses Mal wird die vollständige Migration ausgeführt. Wie bereits in diesem Blogartikel erwähnt, erlaubt ZDM das Pausieren des Migrationsprozesses in jeder Phase, einschließlich der Phase vor dem Rollentausch und Switchover. Um den Migrationsprozess anzuhalten, muss beim Ausführen des Migrationsbefehls der Parameter -pauseafter mit der gewünschten Phase angegeben werden, in diesem Fall ZDM_CONFIGURE_DG_SRC
, wie unten gezeigt.
Nun werden alle Phasen der Migration dargestellt, wobei die tatsächliche Migration mehr Phasen umfasst als die Evaluierung. Dies liegt daran, dass die Evaluierung nur die Voraussetzungen und Konfigurationen überprüft, während die tatsächliche Migration zusätzliche Schritte wie Backups, Datenübertragung, Data Guard-Konfiguration, Switchover und Aufräumarbeiten beinhaltet.
Es ist zu beachten, dass der aktuelle Auftragsstatus jetzt im PAUSED-Status ist und der Fortschritt nach Abschluss der Phase ZDM_CONFIGURE_DG_SRC
gestoppt wurde.
Wenn man die Datenbankrollen überprüft, wird festgestellt, dass die Quelldatenbank die primäre Datenbank und die Zieldatenbank die physische Standby-Datenbank ist. In dieser Phase werden alle Änderungen in der Quelldatenbank automatisch mit der Zieldatenbank synchronisiert. Der Migrationsauftrag setzt fort, sobald die Nutzeranwendungen bereit sind.
Der Migrationsprozess, der im vorherigen Schritt pausiert wurde, kann wieder aufgenommen werden.
Nach dem Fortsetzen des Migrationsprozesses werden alle Phasen abgeschlossen. Sobald der gesamte Prozess erfolgreich beendet ist, werden die Rollen der Datenbanken erneut überprüft. Dabei wird festgestellt, dass die Quelldatenbank jetzt die Standby-Datenbank ist und die Zieldatenbank die primäre Datenbank. Damit ist die Migration erfolgreich abgeschlossen und das System ist bereit für den produktiven Betrieb in der neuen Umgebung.
Fazit
Zusammenfassend zeigt der Beitrag, dass die Migration von Oracle-Datenbanken in die Cloud mit Zero Downtime Migration reibungslos und ohne Unterbrechungen erfolgen kann. Unternehmen können ihre Datenbanken sicher in die OCI migrieren und dabei sowohl die Datenverfügbarkeit als auch die Integrität bewahren. Dieser Ansatz minimiert Risiken und maximiert die Effizienz während des Migrationsprozesses. So wird der Übergang in die Cloud zu einer planbaren und kontrollierten Maßnahme.
Seminarempfehlung
ORACLE CLOUD INFRASTRUCTURE (OCI) FÜR ORACLE DBAS
Mehr erfahren