ビルド環境 build-environment

Cloud Manager ユーザーがコードを作成およびテストするための専用のビルド環境について説明します。

環境の詳細 details

Cloud Manager のビルド環境には、次の属性があります。

  • ビルド環境は Linux ベースで、Ubuntu 22.04 から派生しています。

  • Apache Maven 3.9.4 がインストールされています。

  • インストールされる Java バージョンは Oracle JDK 8u401 と Oracle JDK 11.0.22 です。

    • /usr/lib/jvm/jdk1.8.0_401
    • /usr/lib/jvm/jdk-11.0.22
  • デフォルトでは、JAVA_HOME 環境変数は /usr/lib/jvm/jdk1.8.0_401 に設定されています。これには、Oracle JDK 8u401 が含まれています。 詳しくは、Maven 実行の代替 JDK バージョンの節を参照してください。

  • 必要に応じてインストールされる追加のシステムパッケージが、次のようにいくつかあります。

    • bzip2
    • unzip
    • libpng
    • imagemagick
    • graphicsmagick
  • 追加のシステムパッケージのインストールの節で説明されているように、ビルド時にその他のパッケージがインストールされる場合があります。

  • どのビルドも、初期状態の環境で実行されます。 ビルドコンテナは実行間で状態を保持しません。

  • Mavenは、次の3つのコマンドで実行されます。

    • mvn --batch-mode org.apache.maven.plugins:maven-dependency-plugin:3.1.2:resolve-plugins
    • mvn --batch-mode org.apache.maven.plugins:maven-clean-plugin:3.1.0:clean -Dmaven.clean.failOnError=false
    • mvn --batch-mode org.jacoco:jacoco-maven-plugin:prepare-agent package
  • Maven は、settings.xml ファイルを使用してシステムレベルで設定されます。このファイルには、adobe-public というプロファイルを使用したアドビの公開アーティファクトリポジトリが自動的に含まれています 詳しくは、アドビの公開 Maven リポジトリを参照してください。

  • Node.js 18 は、フロントエンドパイプラインで使用できます。

IMPORTANT
Maven ツールチェーンのサポートは、Cloud Manager 2025.06.0で削除されました。 JDKの選択は、.cloudmanager/java-versionを通じてのみサポートされるようになりました。 詳しくは、特定のJava バージョンの使用を参照してください。
NOTE
Cloud Manager では、jacoco-maven-plugin の特定のバージョンは定義されませんが、使用するバージョンは 0.7.5.201505241946 以上である必要があります。
TIP
Cloud Manager API の使用方法については、次の追加リソースを参照してください。

HTTPS Maven リポジトリ https-maven

Cloud Manager 2023.10.0は、ビルド環境のローリングアップデート(2023.12.0 リリースで完了)を開始しました。これには、Maven 3.8.8へのアップデートが含まれています。 Maven 3.8.1で導入された大きな変更は、潜在的な脆弱性を軽減するためのセキュリティ強化でした。 具体的には、Maven リリースノートで説明するように、Maven では安全でないすべての http://* ミラーをデフォルトで無効にするようになりました。

このセキュリティ強化の結果、一部のユーザーには、ビルド手順で、特に安全でない HTTP 接続を使用する Maven リポジトリからアーティファクトをダウンロードする際に問題が発生する場合があります。

アップデートされたバージョンでスムーズなエクスペリエンスを実現するために、アドビでは、ユーザーが Mavenリポジトリを更新して HTTP ではなく HTTPS を使用することをお勧めします。 この調整は、業界でセキュアな通信プロトコルへの移行が進むのに合わせて行われ、安全で信頼性の高いビルドプロセスを維持するのに役立ちます。

特定の Java バージョンの使用 using-java-version

デフォルトでは、Cloud Manager ビルドプロセスでビルドされたプロジェクトは、Oracle 8 JDK を使用します。 代替JDKを使用したいお客様は、Maven実行プロセス全体で代替JDK バージョンを選択できます。

IMPORTANT
Maven ツールチェーンは、Cloud Manager 2025.06.0ではサポートされなくなりました。 maven-toolchains-plugin設定を含むパイプラインがCannot find matching toolchain definitions.で失敗することに注意してください。.cloudmanager/java-version ファイルを使用して、代わりにJDK 11、17または21を選択してください。
移行ガイダンス:
  1. ソースコントロールにコミットされているorg.apache.maven.plugins:maven-toolchains-plugin エントリとtoolchains.xmlをすべて削除して、ツールチェーンを削除します。
  2. 代替Maven実行JDK バージョン ​の説明に従って、.cloudmanager/java-version (21、17または11)のJDKを選択します。
  3. Adobeでは、Cloud Manager ビルドキャッシュをクリアするか、新しいパイプライン実行をトリガーすることをお勧めします。

Maven 実行の代替 JDK バージョン alternate-maven

Mavenの実行全体のJDKとして、Oracle 8またはOracle 11を選択できます。 この方法では、すべてのプラグインに使用されるJDKが変更されます。 その結果、Apache Maven Enforcer Plug-in を使用して Java バージョンを確認および強制することができます。

このプロセスを実行するには、パイプラインで使用される Git リポジトリ分岐に .cloudmanager/java-version というファイルを作成します。 このファイルの内容は 118 のどちらかにすることができます。 その他の値は無視されます。 11が指定されている場合、システムはOracle 11を使用し、JAVA_HOME環境変数を/usr/lib/jvm/jdk-11.0.22に設定します。 8が指定されている場合、システムはOracle 8を使用し、JAVA_HOME環境変数を/usr/lib/jvm/jdk1.8.0_401に設定します。

環境変数 environment-variables

標準環境変数 standard-environ-variables

場合によっては、プログラムやパイプラインに関する情報に基づいてビルドプロセスを変更する必要があります。

例えば、JavaScript の縮小に gulp などのツールを使用する場合、開発環境とステージング環境および本番環境で異なる縮小レベルを使用することをお勧めします。

これをサポートするために、Cloud Manager では、実行ごとに標準環境変数をビルドコンテナに追加します。

変数名
説明
CM_BUILD
常に true に設定
BRANCH
実行用に設定されたブランチ
CM_PIPELINE_ID
数値パイプライン識別子
CM_PIPELINE_NAME
パイプライン名
CM_PROGRAM_ID
数値プログラム識別子
CM_PROGRAM_NAME
プログラム名
ARTIFACTS_VERSION
ステージングパイプラインまたは実稼動パイプラインの場合、Cloud Manager で生成された合成バージョン

標準環境変数の可用性 availability

標準環境変数は、様々な場所で使用できます。

オーサー、プレビュー、パブリッシュの各環境 author-preview-publish

オーサー、プレビュー、パブリッシュの各環境では、通常の環境変数とシークレットの両方を使用できます。

Dispatcher dispatcher

Dispatcher で使用できるのは、通常の環境変数のみです。 秘密鍵は使用できません。

ただし、環境変数は IfDefine ディレクティブでは使用できません。

TIP
デプロイする前に、Dispatcher をローカルで使用して、環境変数の使用を検証します。

OSGi 設定 osgi

OSGi 設定では、通常の環境変数とシークレットの両方を使用できます。

パイプライン変数 pipeline-variables

場合によっては、ビルドプロセスが、特定の設定変数に依存している可能性があります。これらの変数が Git リポジトリに配置するのに適していない場合や、同じ分岐を使用するパイプライン実行間で変更する必要があります。

Cloud Manager では、これらの変数を Cloud Manager API または Cloud Manager CLI を介してパイプラインごとに設定できます。 変数は、プレーンテキストとして保存することも、保存時に暗号化することもできます。 どちらの場合も、変数はビルド環境内で環境変数として使用可能になり、変数は pom.xml ファイル内または他のビルドスクリプト内から参照できます。

CLI を使用して変数を設定するには、次のようなコマンドを実行します。

$ aio cloudmanager:set-pipeline-variables PIPELINEID --variable MY_CUSTOM_VARIABLE test

現在の変数は、次のようなコマンドを使用して一覧表示できます。

$ aio cloudmanager:list-pipeline-variables PIPELINEID

変数は、一定の制限に従う必要があります。

  • 変数名には、英数字とアンダースコア(_)のみを含めることができます。
    • 慣例により、名前はすべて大文字にする必要があります。
  • 変数の数はパイプラインあたり最大 200 個までです。
  • 各名前は 100 文字未満にする必要があります。
  • 各文字列値は 2048 文字未満にする必要があります。
  • secretString 値は 500 文字未満にする必要があります。

Maven pom.xml ファイル内で使用する場合は、通常、次のような構文を使用して、これらの変数を Maven プロパティにマッピングすると便利です。

        <profile>
            <id>cmBuild</id>
            <activation>
                <property>
                    <name>env.CM_BUILD</name>
                </property>
            </activation>
            <properties>
                <my.custom.property>${env.MY_CUSTOM_VARIABLE}</my.custom.property>
            </properties>
        </profile>

追加のシステムパッケージのインストール installing-additional-system-packages

完全に機能させるために、一部のビルドでは追加のシステムパッケージをインストールする必要があります。 例えば、Python や Ruby のスクリプトを呼び出す可能性のあるビルドでは、適切な言語インタープリターをインストールしておく必要があります。 このシナリオは、exec-maven-plugin を呼び出して、APT を起動することで実行できます。 この実行は通常、Cloud Manager 固有の Maven プロファイルにラップされます。 例えば、Python のインストールでは、次の操作を実行できます。

        <profile>
            <id>install-python</id>
            <activation>
                <property>
                        <name>env.CM_BUILD</name>
                </property>
            </activation>
            <build>
                <plugins>
                    <plugin>
                        <groupId>org.codehaus.mojo</groupId>
                        <artifactId>exec-maven-plugin</artifactId>
                        <version>1.6.0</version>
                        <executions>
                            <execution>
                                <id>apt-get-update</id>
                                <phase>validate</phase>
                                <goals>
                                    <goal>exec</goal>
                                </goals>
                                <configuration>
                                    <executable>apt-get</executable>
                                    <arguments>
                                        <argument>update</argument>
                                    </arguments>
                                </configuration>
                            </execution>
                            <execution>
                                <id>install-python</id>
                                <phase>validate</phase>
                                <goals>
                                    <goal>exec</goal>
                                </goals>
                                <configuration>
                                    <executable>apt-get</executable>
                                    <arguments>
                                        <argument>install</argument>
                                        <argument>-y</argument>
                                        <argument>--no-install-recommends</argument>
                                        <argument>python</argument>
                                    </arguments>
                                </configuration>
                            </execution>
                        </executions>
                    </plugin>
                </plugins>
            </build>
        </profile>

また、この方法を使用して、言語固有のパッケージをインストールすることもできます。 つまり、RubyGems には gem、Python パッケージには pip を使用します。

NOTE
この方法でシステムパッケージをインストールしても、Adobe Experience Manager の実行に使用されているランタイム環境にはインストールされません。 AEM 環境にシステムパッケージをインストールする必要がある場合は、アドビ担当者にお問い合わせください。
recommendation-more-help
c6cdc82b-cee9-48e0-a6ee-48149d5e72c3