建置環境 build-environment
了解 Cloud Manager 使用者用於建置和測試程式碼的專用建置環境。
環境詳細資訊 details
Cloud Manager 的建置環境有下列屬性。
-
建置環境以 Linux 為基礎,衍生自 Ubuntu 22.04。
-
已安裝 Apache Maven 3.9.4。
- Adobe 建議使用者更新其 Maven 存放庫以使用 HTTPS 而非 HTTP。
-
已安裝的 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使用下列三個命令執行:
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
-
在系統層級使用
settings.xml
檔案設定 Maven,其會利用名為adobe-public
的設定檔自動納入公共 Adobe 成品存放庫。如需更多詳細資訊,請參閱 Adobe 公共 Maven 存放庫。 -
Node.js 18 可用於前端管道。
.cloudmanager/java-version
選取JDK。 如需詳細資訊,請參閱使用特定的Java版本。jacoco-maven-plugin
的特定版本,但使用的版本必須至少為 0.7.5.201505241946
。HTTPS Maven 存放庫 https-maven
Cloud Manager 2023.10.0 版開始推出建置環境的更新 (在 2023.12.0 版時完成),其中包含 Maven 3.8.8 的更新。Maven 3.8.1 引入的一項重大變更是旨在減少潛在漏洞的一項安全性增強。具體而言,Maven 現在預設停用所有不安全的 http://*
鏡像,如 Maven 發行說明中所述。
由於此安全性增強,某些使用者可能會在建置步驟中遇到問題,特別是從使用不安全 HTTP 連線的 Maven 存放庫下載成品時。
為了確保更新的版本有流暢的使用體驗,Adobe 建議使用者更新其 Maven 存放庫以使用 HTTPS 而非 HTTP。這項調整符合產業日益轉向使用安全通訊協定的趨勢,有助於維持安全可靠的建置程序。
使用特定 Java 版本 using-java-version
在預設情況下,由 Cloud Manager 建置程序建置的專案使用 Oracle 8 JDK。想要使用替代JDK的客戶可以為整個Maven執行流程選擇替代JDK版本。
Cannot find matching toolchain definitions.
請使用.cloudmanager/java-version
檔案來選取JDK 11、17或21。- 透過刪除任何
org.apache.maven.plugins:maven-toolchains-plugin
專案以及任何認可至您原始檔控制項的toolchains.xml
來移除工具鏈。 - 挑選具有
.cloudmanager/java-version
(21、17或11)的JDK,如備用Maven執行JDK版本中所述。 - Adobe建議清除Cloud Manager組建快取或觸發新的管道執行。
備用 Maven 執行 JDK 版本 alternate-maven
您可以選取Oracle 8或Oracle 11作為整個Maven執行的JDK。 此方法會變更用於所有外掛程式的JDK。 於是,利用 Apache Maven Enforcer Plug-in 來檢查和強制執行 Java 版本變成有效的方法。
為進行此程序,可在管道使用的 Git 存放庫分支中建立名為 .cloudmanager/java-version
的檔案。本檔案可能有的內容為 11
或 8
。任何其他值會受到忽略。若指定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
在部分情況下,您可能會發現有必要根據關於方案或管道的資訊來改變建置程序。
例如,當透過 gulp 之類的工具進行 JavaScript 縮製時,您可能會比較希望針對開發環境,而不是中繼和生產環境來使用不同的縮製程度。
為了支援這一點,Cloud Manager 會在每次執行時將標準環境變數新增到組建容器中。
CM_BUILD
true
BRANCH
CM_PIPELINE_ID
CM_PIPELINE_NAME
CM_PROGRAM_ID
CM_PROGRAM_NAME
ARTIFACTS_VERSION
標準環境變數可用性 availability
標準環境變數可以用在很多地方。
作者、預覽和發佈環境 author-preview-publish
一般環境變數和密碼均可用於編寫、預覽和發佈環境。
Dispatcher dispatcher
Dispatcher 只能使用一般環境變數。不能使用密碼。
但不能在 IfDefine
指令中使用環境變數。
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
。