Einrichten eines Projekts setting-up-your-project
Erfahren Sie, wie Sie Ihr Projekt einrichten, damit Sie es mit Cloud Manager verwalten und bereitstellen können.
Bearbeiten vorhandener Projekte modifying-project-setup-details
Vorhandene AEM-Projekte müssen bestimmte Grundregeln einhalten, damit sie erfolgreich mit Cloud Manager erstellt und bereitgestellt werden können.
-
Projekte müssen mit Apache Maven erstellt werden.
-
Im Stammverzeichnis des Git-Repositorys muss eine Datei
pom.xml
vorhanden sein.- Diese
pom.xml
-Datei kann auf beliebig viele Untermodule verweisen (die wiederum weitere Untermodule umfassen usw.). - Sie können Verweise auf weitere Maven-Artefakt-Repositorys in Ihren
pom.xml
-Dateien hinzufügen. - Der Zugriff auf kennwortgeschützte Artefakt-Repositorys wird bei entsprechender Konfiguration unterstützt. Allerdings wird der Zugriff auf netzwerkgeschützte Artefakte nicht unterstützt.
- Diese
-
Bereitstellbare Inhaltspakete werden erkannt, wenn Sie nach Inhaltspaketen im .zip-Format suchen, die in einem Verzeichnis mit dem Namen
target
enthalten sind.- Eine beliebige Anzahl von Untermodulen kann Inhaltspakete produzieren.
-
Bereitstellbare Dispatcher-Artefakte werden erkannt, wenn Sie nach
zip
-Dateien suchen, die Unterverzeichnisse vontarget
mit den Namenconf
undconf.d
enthalten. -
Wenn mehrere Inhaltspakete vorhanden sind, ist die Reihenfolge der Paketbereitstellungen nicht garantiert.
-
Wenn eine bestimmte Reihenfolge benötigt wird, können die Abhängigkeiten des Inhaltspakets zum Definieren der Reihenfolge verwendet werden.
-
Pakete können bei der Bereitstellung übersprungen werden.
Aktivieren von Maven-Profilen in Cloud Manager activating-maven-profiles-in-cloud-manager
In einigen wenigen Fällen müssen Sie den Build-Prozess möglicherweise etwas anders gestalten, wenn er in Cloud Manager und auf Entwickler-Workstations ausgeführt wird. In diesen Fällen können Sie mit Maven-Profilen definieren, wie der Build in verschiedenen Umgebungen (einschließlich Cloud Manager) abweichen soll.
Die Aktivierung eines Maven-Profils innerhalb der Cloud Manager-Build-Umgebung sollte durch Suchen nach der Umgebungsvariablen CM_BUILD
erfolgen. Beim Erstellen eines Profils, das nur außerhalb der Cloud Manager-Build-Umgebung verwendet werden soll, sollte hingegen das Nichtvorhandensein dieser Variable verifiziert werden.
Wenn zum Beispiel eine einfache Nachricht nur dann ausgegeben werden soll, wenn der Build innerhalb von Cloud Manager ausgeführt wird, verwenden Sie Folgendes:
<profile>
<id>cmBuild</id>
<activation>
<property>
<name>env.CM_BUILD</name>
</property>
</activation>
<build>
<plugins>
<plugin>
<artifactId>maven-antrun-plugin</artifactId>
<version>1.8</version>
<executions>
<execution>
<phase>initialize</phase>
<configuration>
<target>
<echo>I'm running inside Cloud Manager!</echo>
</target>
</configuration>
<goals>
<goal>run</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
-PcmBuild
) oder in der integrierten Entwicklungsumgebung (IDE) aktivieren.Wenn zum Beispiel eine einfache Nachricht nur dann ausgegeben werden soll, wenn der Build außerhalb von Cloud Manager ausgeführt wird, verwenden Sie Folgendes:
<profile>
<id>notCMBuild</id>
<activation>
<property>
<name>!env.CM_BUILD</name>
</property>
</activation>
<build>
<plugins>
<plugin>
<artifactId>maven-antrun-plugin</artifactId>
<version>1.8</version>
<executions>
<execution>
<phase>initialize</phase>
<configuration>
<target>
<echo>I'm running outside Cloud Manager!</echo>
</target>
</configuration>
<goals>
<goal>run</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>
Unterstützung für kennwortgeschützte Maven-Repositorys password-protected-maven-repositories
Artefakte aus einem kennwortgeschützten Maven-Repository sollten mit Vorsicht verwendet werden, da auf diese Weise bereitgestellter Code nicht vollumfänglich den Qualitätsprüfungen der Cloud Manager-Qualitäts-Gates unterzogen wird. Adobe empfiehlt, neben der Binärdatei auch die Java-Quellen sowie den gesamten Quell-Code des Projekts bereitzustellen.
Um ein kennwortgeschütztes Maven-Repository aus Cloud Manager zu verwenden, geben Sie das Kennwort (und optional den Benutzernamen) als geheime Pipeline-Variable an und verweisen Sie dann in einer Datei im Git-Repository mit dem Namen .cloudmanager/maven/settings.xml
auf dieses Geheimnis. Diese Datei folgt dem Schema der Maven-Einstellungsdatei.
Wenn der Build-Vorgang von Cloud Manager gestartet wird, wird das Element <servers>
in dieser Datei mit der von Cloud Manager bereitgestellten Standarddatei settings.xml
zusammengeführt. Benutzerdefinierte Server sollten keine Server-IDs verwenden, die mit adobe
und cloud-manager
beginnen. Solche IDs werden als reserviert betrachtet. Cloud Manager spiegelt nur die Server-IDs wider, die mit einem der angegebenen Präfixe oder der standardmäßigen ID central
übereinstimmen.
Wenn diese Datei vorhanden ist, wird die Server-ID von innerhalb eines <repository>
- und/oder <pluginRepository>
-Elements in der pom.xml
-Datei referenziert. Im Allgemeinen wären diese <repository>
- und/oder <pluginRepository>
-Elemente in einem Cloud Manager-spezifischen Profil enthalten, auch wenn dies nicht unbedingt erforderlich ist.
Angenommen, das Repository befindet sich unter https://repository.myco.com/maven2
, der von Cloud Manager zu verwendende Benutzername ist cloudmanager
und das Kennwort lautet secretword
.
Legen Sie zunächst in der Pipeline das Kennwort als Geheimnis fest:
$ aio cloudmanager:set-pipeline-variables PIPELINEID --secret CUSTOM_MYCO_REPOSITORY_PASSWORD secretword
Verweisen Sie dann über die Datei .cloudmanager/maven/settings.xml
auf Folgendes:
<?xml version="1.0" encoding="UTF-8"?>
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">
<servers>
<server>
<id>myco-repository</id>
<username>cloudmanager</username>
<password>${env.CUSTOM_MYCO_REPOSITORY_PASSWORD}</password>
</server>
</servers>
</settings>
Verweisen Sie schließlich in der Datei pom.xml
auf die Server-ID:
<profiles>
<profile>
<id>cmBuild</id>
<activation>
<property>
<name>env.CM_BUILD</name>
</property>
</activation>
<build>
<repositories>
<repository>
<id>myco-repository</id>
<name>MyCo Releases</name>
<url>https://repository.myco.com/maven2</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
<releases>
<enabled>true</enabled>
</releases>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>myco-repository</id>
<name>MyCo Releases</name>
<url>https://repository.myco.com/maven2</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
<releases>
<enabled>true</enabled>
</releases>
</pluginRepository>
</pluginRepositories>
</build>
</profile>
</profiles>
Bereitstellen von Quellen deploying-sources
Es empfiehlt sich, die Java-Quellen zusammen mit der Binärdatei in einem Maven-Repository bereitzustellen.
Konfigurieren Sie das maven-source-plugin
in Ihrem Projekt.
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-source-plugin</artifactId>
<executions>
<execution>
<id>attach-sources</id>
<goals>
<goal>jar-no-fork</goal>
</goals>
</execution>
</executions>
</plugin>
Bereitstellen von Projektquellen deploying-project-sources
Es empfiehlt sich, die gesamte Projekt-Quelle zusammen mit der Binärdatei in einem Maven-Repository bereitzustellen. Dadurch kann das genaue Artefakt neu erstellt werden.
Konfigurieren Sie das maven-assembly-plugin
in Ihrem Projekt.
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-assembly-plugin</artifactId>
<executions>
<execution>
<id>project-assembly</id>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
<configuration>
<descriptorRefs>
<descriptorRef>project</descriptorRef>
</descriptorRefs>
</configuration>
</execution>
</executions>
</plugin>
Überspringen von Inhaltspaketen skipping-content-packages
In Cloud Manager können Builds eine beliebige Anzahl von Inhaltspaketen generieren. Aus vielerlei Gründen kann es sinnvoll sein, ein Inhaltspaket zu erstellen, es jedoch nicht bereitzustellen. Dieser Ansatz kann beispielsweise nützlich sein, wenn Sie Inhaltspakete ausschließlich zum Testen erstellen oder wenn diese durch einen anderen Schritt im Build-Prozess neu verpackt werden. Das heißt, sie werden zum Unterpaket eines anderen Pakets.
Um diesen Szenarien gerecht zu werden, sucht Cloud Manager in den Eigenschaften erstellter Inhaltspakete nach einer Eigenschaft namens cloudManagerTarget
. Wenn diese Eigenschaft auf none
festgelegt ist, wird das Paket übersprungen und nicht bereitgestellt. Der Mechanismus zum Festlegen dieser Eigenschaft hängt davon ab, wie der Build das Inhaltspaket erzeugt. Mit filevault-maven-plugin
würden Sie beispielsweise das Plug-in wie folgt konfigurieren:
<plugin>
<groupId>org.apache.jackrabbit</groupId>
<artifactId>filevault-package-maven-plugin</artifactId>
<extensions>true</extensions>
<configuration>
<properties>
<cloudManagerTarget>none</cloudManagerTarget>
</properties>
<!-- other configuration -->
</configuration>
</plugin>
Mit content-package-maven-plugin
ist es ähnlich:
<plugin>
<groupId>com.day.jcr.vault</groupId>
<artifactId>content-package-maven-plugin</artifactId>
<extensions>true</extensions>
<configuration>
<properties>
<cloudManagerTarget>none</cloudManagerTarget>
</properties>
<!-- other configuration -->
</configuration>
</plugin>
Wiederverwenden von Build-Artefakten build-artifact-reuse
In vielen Fällen wird derselbe Code in mehreren AEM-Umgebungen bereitgestellt. Wenn festgestellt wird, dass derselbe Git-Commit in mehreren Full-Stack-Pipeline-Ausführungen verwendet wird, verhindert Cloud Manager nach Möglichkeit eine Neuerstellung der Code-Basis.
Wenn eine Ausführung gestartet wird, wird der aktuelle HEAD-Commit für die Zweig-Pipeline extrahiert. Der Commit-Hash ist in der Benutzeroberfläche und über die API sichtbar. Wenn der Build-Schritt erfolgreich abgeschlossen wurde, werden die resultierenden Artefakte basierend auf diesem Commit-Hash gespeichert und können in nachfolgenden Pipeline-Ausführungen wiederverwendet werden.
Pakete werden in allen Pipelines wiederverwendet, wenn sie sich im selben Programm befinden. Bei der Suche nach Paketen, die wiederverwendet werden können, ignoriert AEM Verzweigungen und verwendet Artefakte in allen Verzweigungen wieder.
Wenn eine Wiederverwendung erfolgt, werden die Build- und Code-Qualitätsschritte effektiv durch die Ergebnisse der ursprünglichen Ausführung ersetzt. In der Protokolldatei für den Build-Schritt werden die Artefakte und die Ausführungsinformationen aufgelistet, die ursprünglich zum Erstellen verwendet wurden.
Im Folgenden finden Sie ein Beispiel für eine solche Protokollausgabe.
The following build artifacts were reused from the prior execution 4 of pipeline 1 which used commit f6ac5e6943ba8bce8804086241ba28bd94909aef:
build/aem-guides-wknd.all-2021.1216.1101633.0000884042.zip (content-package)
build/aem-guides-wknd.dispatcher.cloud-2021.1216.1101633.0000884042.zip (dispatcher-configuration)
Das Protokoll des Code-Qualitätsschritts enthält ähnliche Informationen.
Beispiele example-reuse
Beispiel 1 example-1
Beachten Sie, dass Ihr Programm über zwei Entwicklungs-Pipelines verfügt:
- Pipeline 1 auf Verzweigung
foo
- Pipeline 2 auf Verzweigung
bar
Beide Verzweigungen befinden sich auf derselben Commit-ID.
- Wenn Sie zuerst Pipeline 1 ausführen, werden die Pakete normal erstellt.
- Wenn Sie dann Pipeline 2 ausführen, werden von Pipeline 1 erstellte Pakete wiederverwendet.
Beispiel 2 example-2
Beachten Sie, dass Ihr Programm über zwei Verzweigungen verfügt: die Verzweigung foo
und die Verzweigung bar
.
Beide Verzweigungen haben dieselbe Commit-ID.
- Eine Entwicklungs-Pipeline erstellt
foo
und führt sie aus. - Anschließend erstellt eine Produktions-Pipeline
bar
und führt sie aus.
In diesem Fall wird das Artefakt von foo
für die Produktions-Pipeline wiederverwendet, da derselbe Commit-Hash erkannt wurde.
Opt-out opting-out
Falls gewünscht, kann das Wiederverwendungsverhalten für bestimmte Pipelines deaktiviert werden, indem die Pipeline-Variable CM_DISABLE_BUILD_REUSE
auf true
festgelegt wird. Wenn diese Variable festgelegt ist, wird der Commit-Hash weiterhin extrahiert. Die resultierenden Artefakte werden zur späteren Verwendung gespeichert, aber zuvor gespeicherte Artefakte werden nicht wiederverwendet. Um dieses Verhalten zu verstehen, sehen Sie sich das folgende Szenario an.
- Eine neue Pipeline wird erstellt.
- Die Pipeline wird ausgeführt (Ausführung #1) und der aktuelle HEAD-Commit lautet
becdddb
. Die Ausführung ist erfolgreich und die resultierenden Artefakte werden gespeichert. - Die Variable
CM_DISABLE_BUILD_REUSE
ist festgelegt. - Die Pipeline wird erneut ausgeführt, ohne dass der Code geändert wird. Obwohl es gespeicherte Artefakte gibt, die mit
becdddb
verknüpft sind, werden sie aufgrund der VariablenCM_DISABLE_BUILD_REUSE
nicht wiederverwendet. - Der Code wird geändert und die Pipeline wird ausgeführt. Der HEAD-Commit ist jetzt
f6ac5e6
. Die Ausführung ist erfolgreich und die resultierenden Artefakte werden gespeichert. - Die Variable
CM_DISABLE_BUILD_REUSE
wird gelöscht. - Die Pipeline wird erneut ausgeführt, ohne dass der Code geändert wird. Da es gespeicherte Artefakte gibt, die mit
f6ac5e6
verknüpft sind, werden diese Artefakte wiederverwendet.
Einschränkungen caveats
- Build-Artefakte werden nicht in verschiedenen Programmen wiederverwendet, unabhängig davon, ob der Commit-Hash identisch ist.
- Build-Artefakte werden innerhalb desselben Programms wiederverwendet, selbst wenn die Verzweigung und/oder die Pipeline unterschiedlich sind.
- Der Umgang mit Maven-Versionen ersetzt die Projektversion nur in Produktions-Pipelines. Wenn derselbe Commit sowohl für Entwicklungs- als auch für Produktions-Pipelines verwendet und die Entwicklungs-Pipeline zuerst ausgeführt wird, werden die Versionen unverändert für Staging und Produktion bereitgestellt. In diesem Fall wird jedoch nach wie vor ein Tag erstellt.
- Wenn der Abruf der gespeicherten Artefakte nicht erfolgreich ist, wird der Build-Schritt so ausgeführt, als ob keine Artefakte gespeichert worden wären.
- Andere Pipeline-Variablen als
CM_DISABLE_BUILD_REUSE
werden nicht berücksichtigt, wenn Cloud Manager entscheidet, zuvor erstellte Build-Artefakte wiederzuverwenden.
Entwickeln von Code anhand von Best Practices develop-your-code-based-on-best-practices
Die Entwicklungs- und Beratungs-Teams von Adobe haben einen umfassenden Satz an Best Practices für AEM-Entwickelnde zusammengestellt.