Verwendung des CRX2Oak-Migrations-Tools using-the-crx-oak-migration-tool

Einführung introduction

CRX2Oak ist ein Tool, mit dem Daten zwischen verschiedenen Repositorys migriert werden können.

Es kann verwendet werden, um Daten von älteren CQ-Versionen, die auf Apache Jackrabbit 2 basieren, nach Oak zu migrieren, und es kann auch verwendet werden, um Daten zwischen Oak-Repositories zu kopieren.

Die aktuelle CRX2OAK-Version kann unter der folgenden Adresse vom öffentlichen Adobe-Repository heruntergeladen werden:https://repo1.maven.org/maven2/com/adobe/granite/crx2oak/

NOTE
Weitere Informationen zu Apache Oak und den Schlüsselkonzepten der Adobe Experience Manager-Persistenz (AEM) finden Sie unter Einführung in die AEM Platform.

Migrationsanwendungsfälle migration-use-cases

Das Tool kann für Folgendes verwendet werden:

  • Migration von älteren CQ 5-Versionen nach AEM 6
  • Kopieren von Daten zwischen mehreren Oak-Repositorys
  • Konvertieren von Daten zwischen verschiedenen Oak-MicroKernel-Implementierungen.

Die Unterstützung für die Migration von Repositorys mit externen BLOB-Speichern (allgemein als Datenspeicher bekannt) wird in unterschiedlicher Form bereitgestellt. Ein möglicher Migrationspfad ist von einem CRX2-Repository, das einen externen FileDataStore nutzt, auf ein Oak-Repository, das einen S3DataStore verwendet.

Das nachfolgende Diagramm zeigt alle von CRX2Oak unterstützten Migrationsoptionen:

chlimage_1-151

Funktionen features

CRX2OAK wird bei AEM-Aktualisierungen aufgerufen. Dabei kann der Benutzer ein vordefiniertes Migrationsprofil angeben, das die Rekonfiguration von Persistenzmodi automatisiert. Dies wird als Schnellstartmodus bezeichnet.

Das Tool kann auch separat ausgeführt werden, für den Fall, dass eine umfassendere Anpassung erforderlich ist. In diesem Modus werden Änderungen jedoch nur am Repository vorgenommen und jede zusätzliche Neukonfiguration von AEM muss manuell durchgeführt werden. Dies wird als eigenständiger Modus bezeichnet.

Beachten Sie auch, dass mit den Standardeinstellungen im eigenständigen Modus nur der Knotenspeicher migriert wird und das neue Repository den alten binären Speicher wiederverwendet.

Automatisierter Schnellstartmodus automated-quickstart-mode

Seit AEM 6.3 kann CRX2Oak benutzerdefinierte Migrationsprofile verarbeiten, die mit allen bereits verfügbaren Migrationsoptionen konfiguriert werden können. Dies ermöglicht sowohl höhere Flexibilität als auch die Möglichkeit, die Konfiguration von AEM zu automatisieren. Funktionen wie diese stehen nicht zur Verfügung, wenn Sie das Tool im eigenständigen Modus verwenden.

Um CRX2Oak in den Schnellstartmodus zu wechseln, definieren Sie den Pfad zum Ordner crx-quickstart im AEM Installationsverzeichnis mithilfe dieser Umgebungsvariablen des Betriebssystems:

Für UNIX-basierte Systeme und macOS:

export SLING_HOME="/path/to/crx-quickstart"

Für Windows:

SET "SLING_HOME=/path/to/crx-quickstart"

Fortsetzung der Unterstützung resume-support

Die Migration kann jederzeit unterbrochen werden, um danach wieder aufgenommen zu werden.

Anpassbare Upgrade-Logik customizable-upgrade-logic

Benutzerdefinierte Java™-Logik kann mithilfe von CommitHooks. Benutzerdefiniert RepositoryInitializer -Klassen können implementiert werden, um das Repository mit benutzerdefinierten Werten zu initialisieren.

Unterstützung für Speicherzuordnungsvorgänge support-for-memory-mapped-operations

CRX2Oak unterstützt standardmäßig auch speicherzugeordnete Vorgänge. Die Speicherzuordnung verbessert die Leistung erheblich und sollte nach Möglichkeit verwendet werden.

CAUTION
Beachten Sie jedoch, dass speicherzugeordnete Vorgänge für Windows-Plattformen nicht unterstützt werden. Es wird deshalb empfohlen, bei einer Migration unter Windows den Parameter –disable-mmap hinzuzufügen.

Selektive Migration von Inhalten selective-migration-of-content

Standardmäßig migriert das Tool das gesamte Repository unter dem Pfad "/". Sie haben jedoch die vollständige Kontrolle darüber, welche Inhalte migriert werden sollen.

Falls ein Teil der Inhalte auf der neuen Instanz nicht benötigt wird, können Sie diesen Teil mithilfe des Parameters --exclude-path ausschließen und den Upgrade-Vorgang so optimieren.

Zusammenführung von Pfaden path-merging

Wenn Daten zwischen zwei Repositorys kopiert werden müssen und Sie über einen Inhaltspfad verfügen, der in beiden Instanzen unterschiedlich ist, können Sie sie im --merge-path -Parameter. Wenn Sie dies tun, kopiert CRX2Oak nur die neuen Knoten in das Ziel-Repository und behält die alten bei.

chlimage_1-152

Versionsunterstützung version-support

Standardmäßig erstellt AEM eine Version jedes Knotens oder jeder Seite, der bzw. die geändert wird, und speichert sie im Repository. Die Versionen können dann verwendet werden, um die Seite in einem früheren Zustand wiederherzustellen.

Allerdings werden diese Versionen nie bereinigt, auch wenn die Originalseite gelöscht wird. Wenn es um Repositorys geht, die seit langem in Betrieb sind, kann die Migration redundante Daten, die durch verwaiste Versionen verursacht wurden, erneut verarbeiten.

In Szenarien wie diesen ist das Hinzufügen des Parameters --copy-versions nützlich. Es kann verwendet werden, um Versionsknoten während der Migration oder beim Kopieren eines Repositorys zu überspringen.

Darüber hinaus können Sie festlegen, ob verwaiste Versionen kopiert werden sollen, indem Sie --copy-orphaned-versions=true hinzufügen.

Beide Parameter unterstützen außerdem das Datumsformat YYYY-MM-DD, falls Sie Versionen bis zu einem bestimmten Datum kopieren möchten.

chlimage_1-153

Open-Source-Version open-source-version

Eine Open-Source-Version von CRX2Oak ist als Oak-Upgrade verfügbar. Sie unterstützt alle Funktionen, mit Ausnahme von:

  • CRX2-Unterstützung
  • Unterstützung für Migrationsprofile
  • Unterstützung für die automatische AEM-Neukonfiguration

Weitere Informationen finden Sie in der Apache-Dokumentation.

Parameter parameters

Knotenspeicheroptionen node-store-options

  • --cache: Die Cache-Größe in MB (der Standardwert beträgt 256)

  • --mmap: Aktivieren des Zugriffs auf die Speicherdatei für die Segmentspeicherung

  • --src-password:: Das Kennwort für die RDB-Quell-Datenbank

  • --src-user:: Der Benutzer für die Quell-RDB

  • --user: Benutzer für die Ziel-RDB

  • --password: Das Kennwort für die Ziel-RDB

Migrationsoptionen migration-options

  • --early-shutdown: Fährt das JCR2-Quell-Repository nach dem Kopieren der Knoten herunter, bevor die CommitHooks angewendet werden

  • --fail-on-error: Erzwingt ein Fehlschlagen der Migration, wenn die Knoten nicht aus dem Quell-Repository gelesen werden können.

  • --ldap: Migriert LDAP-Benutzer von einer CQ 5.x-Instanz auf eine Oak-basierte Instanz. Damit dies funktioniert, muss der Identitätsanbieter in der Oak-Konfiguration ldap genannt werden. Weitere Informationen finden Sie in der LDAP-Dokumentation.

  • --ldap-config: Verwenden Sie dies mit dem --ldap Parameter für CQ 5.x-Repositorys, die mehrere LDAP-Server zur Authentifizierung verwendet haben. Sie können damit auf die CQ 5.x-Konfigurationsdateien ldap_login.conf oder jaas.conf verweisen. Das Format lautet --ldapconfig=path/to/ldap_login.conf.

Optionen für die Versionsspeicherung version-store-options

  • --copy-orphaned-versions: Überspringt das Kopieren von verwaisten Versionen. Folgende Parameter werden unterstützt: true, false, und yyyy-mm-dd. Standardwert ist true.

  • --copy-versions:: Kopiert den Versionsspeicher. Parameter: true, false, yyyy-mm-dd. Standardwert ist true.

Pfadoptionen path-options

  • --include-paths:: Eine kommagetrennte Liste der beim Kopieren einzuschließenden Pfade.
  • --merge-paths: Eine kommagetrennte Liste der beim Kopieren zusammenzuführenden Pfade.
  • --exclude-paths:: Eine kommagetrennte Liste der beim Kopieren auszuschließenden Pfade.

Quell BLOB-Speicheroptionen source-blob-store-options

  • --src-datastore:: Das als Quell-FileDataStore zu verwendende Datenspeicherverzeichnis.

  • --src-fileblobstore: Das als Quell-FileBlobStore zu verwendende Datenspeicherverzeichnis.

  • --src-s3datastore: Das für den Quell-S3DataStore zu verwendende Datenspeicherverzeichnis.

  • --src-s3config: Die Konfigurationsdatei für den Quell-S3DataStore.

Ziel BLOB-Speicheroptionen destination-blobstore-options

  • --datastore:: Das als Ziel-FileDataStore zu verwendende Datenspeicherverzeichnis.

  • --fileblobstore:: Das als Ziel-FileBlobStore zu verwendende Datenspeicherverzeichnis.

  • --s3datastore: Das für den Ziel-S3DataStore zu verwendende Datenspeicherverzeichnis.

  • --s3config: Die Konfigurationsdatei für das Ziel-S3DataStore.

Hilfeoptionen help-options

  • -?, -h, --help: Zeigt Hilfeinformationen an.

Debugging debugging

Sie können auch Debugging-Informationen für den Migrationsprozess aktivieren, um Probleme zu beheben, die während des Prozesses auftreten können. Hierzu gibt es verschiedene Optionen, je nachdem, in welchem Modus das Tool ausgeführt werden soll:

CRX2Oak-Modus
Aktion
Quickstart-Modus
Sie können die Optionen --log-level TRACE  oder --log-level DEBUG zur Befehlszeile hinzufügen, wenn Sie CRX2Oak ausführen. In diesem Modus werden Protokolle automatisch an die upgrade.log-Datei.
Standalone-Modus
Fügen Sie die —trace Optionen zur CRX2Oak-Befehlszeile hinzufügen, damit Sie TRACE-Ereignisse bei der Standardausgabe anzeigen können (Sie müssen die Protokolle selbst umleiten, indem Sie für eine spätere Überprüfung den Befehl '>' oder 'tee' verwenden).

Weitere Überlegungen other-considerations

Bei der Migration auf eine MongoDB-Replikatgruppe muss der Parameter WriteConcern für alle Verbindungen mit der Mongo-Datenbank auf 2 gesetzt werden.

Hierzu können Sie den Parameter w=2 wie nachfolgend gezeigt am Ende der Verbindungszeichenfolge hinzufügen:

java -Xmx4092m -jar crx2oak.jar crx-quickstart/repository/ mongodb://localhost:27017/aem-author?replicaset=replica1&w=2
NOTE
Weitere Informationen finden Sie in der Dokumentation zur MongoDB-Verbindungszeichenfolge unter WriteConcerns.
recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2