升級Commerce版本
您可以將Adobe Commerce程式碼基底升級至較新版本。 升級專案之前,請檢閱 安裝 指南中的系統需求,以取得最新的軟體版本需求。
根據您的專案組態,您的升級任務可能包括以下內容:
- 更新服務(例如MariaDB (MySQL)、OpenSearch、RabbitMQ和Redis)以與新Adobe Commerce版本相容。
- 轉換較舊的組態管理檔案。
- 以掛接和環境變數的新設定更新
.magento.app.yaml
檔案。 - 將協力廠商擴充功能升級至最新支援的版本。
- 更新
.gitignore
檔案。
.magento.app.yaml
和services.yaml
檔案,並在票證中說明PHP版本。 如需自行變更PHP版本、擴充功能或環境設定,請參閱_應用程式組態_中的PHP設定。從舊版升級
如果您正在開始從2.1之前的Commerce版本升級,Adobe Commerce程式碼庫中的某些限制可能會影響您 更新 至特定ECE-Tools版本或 升級 至下一個支援的Commerce版本的能力。 請使用下表來決定最佳路徑:
ece-tools
套件的雲端基礎結構上使用Adobe Commerce版本,則您必須對您的雲端專案執行一次性升級以移除已棄用的套件。 如果您目前使用ece-tools
套件,而且需要更新它,請參閱更新ECE-Tools套件。設定管理
舊版Adobe Commerce (例如2.1.4或更新版本至2.2.x或更新版本)使用config.local.php
檔案進行組態管理。 Adobe Commerce 2.2.0版和更新版本使用config.php
檔案,其運作方式與config.local.php
檔案完全相同,但其組態設定不同,其中包含已啟用模組的清單和其他組態選項。
從舊版升級時,您必須移轉config.local.php
檔案以使用較新的config.php
檔案。 使用下列步驟來備份設定檔並建立設定檔。
若要建立暫存config.php
檔案:
-
建立
config.local.php
檔案的復本,並將其命名為config.php
。 -
將此檔案新增至專案的
app/etc
資料夾。 -
新增檔案並將其提交到您的分支。
-
將檔案推送至整合分支。
-
繼續進行升級程式。
config.php
檔案並產生新的完整檔案。 您只能刪除這個檔案來取代它一次。 產生新的、完整的config.php
檔案後,您無法刪除該檔案以產生新的檔案。 請參閱設定管理和管道部署。驗證Zend Framework撰寫器相依性
從2.2.x 升級至 2.3.x或更新版本時,請確認Zend Framework相依性已新增至composer.json
檔案的autoload
屬性,以支援Laminas。 此外掛程式支援Zend Framework的新需求,此架構已移轉至Laminas專案。 請參閱 MagentoDevBlog 上的Zend Framework移轉至Laminas專案。
若要檢查auto-load:psr-4
組態:
-
在本機工作站上,變更至專案目錄。
-
請檢視您的整合分支。
-
在文字編輯器中開啟
composer.json
檔案。 -
檢查Zend外掛程式管理員實作的
autoload:psr-4
區段以瞭解控制器相依性。code language-json "autoload": { "psr-4": { "Magento\\Framework\\": "lib/internal/Magento/Framework/", "Magento\\Setup\\": "setup/src/Magento/Setup/", "Magento\\": "app/code/Magento/", "Zend\\Mvc\\Controller\\": "setup/src/Zend/Mvc/Controller/" }, }
-
如果缺少Zend相依性,請更新
composer.json
檔案:-
將下列行新增至
autoload:psr-4
區段。code language-json "Zend\\Mvc\\Controller\\": "setup/src/Zend/Mvc/Controller/"
-
更新專案相依性。
code language-bash composer update
-
新增、提交和推送程式碼變更。
code language-bash git add -A
code language-bash git commit -m "Add Zend plugin manager implementation for controllers dependency for Laminas support"
code language-bash git push origin <branch-name>
-
先將變更合併到測試環境,然後再合併到生產環境。
-
組態檔
在升級應用程式之前,您必須更新專案設定檔,以考慮雲端基礎結構或應用程式上Adobe Commerce預設設定值的變更。 您可以在magento-cloud GitHub存放庫中找到最新的預設值。
.magento.app.yaml
請一律檢閱.magento.app.yaml檔案中包含的值以取得您安裝的版本,因為它會控制應用程式建置和部署到雲端基礎結構的方式。 以下範例適用於版本2.4.7,並使用撰寫器2.7.2。build: flavor:
屬性不用於Composer 2.x;請參閱安裝及使用Composer 2。
若要更新.magento.app.yaml
檔案:
-
在本機工作站上,變更至專案目錄。
-
開啟並編輯
magento.app.yaml
檔案。 -
更新PHP選項。
code language-yaml type: php:8.3 build: flavor: none dependencies: php: composer/composer: '2.7.2'
-
修改
hooks
屬性build
和deploy
命令。code language-yaml hooks: # We run build hooks before your application has been packaged. build: | set -e composer install php ./vendor/bin/ece-tools run scenario/build/generate.xml php ./vendor/bin/ece-tools run scenario/build/transfer.xml # We run deploy hook after your application has been deployed and started. deploy: | php ./vendor/bin/ece-tools run scenario/deploy.xml # We run post deploy hook to clean and warm the cache. Available with ECE-Tools 2002.0.10. post_deploy: | php ./vendor/bin/ece-tools run scenario/post-deploy.xml
-
將下列環境變數新增至檔案結尾。
適用於Adobe Commerce 2.2.x至2.3.x-
code language-yaml variables: env: CONFIG__DEFAULT__PAYPAL_ONBOARDING__MIDDLEMAN_DOMAIN: 'payment-broker.magento.com' CONFIG__STORES__DEFAULT__PAYMENT__BRAINTREE__CHANNEL: 'Magento_Enterprise_Cloud_BT' CONFIG__STORES__DEFAULT__PAYPAL__NOTATION_CODE: 'Magento_Enterprise_Cloud'
適用於Adobe Commerce 2.4.x-
code language-yaml variables: env: CONFIG__DEFAULT__PAYPAL_ONBOARDING__MIDDLEMAN_DOMAIN: 'payment-broker.magento.com' CONFIG__STORES__DEFAULT__PAYPAL__NOTATION_CODE: 'Magento_Enterprise_Cloud'
-
儲存檔案。 請勿認可或推送變更至遠端環境。
-
繼續進行升級程式。
composer.json
升級之前,請一律檢查composer.json
檔案中的相依性是否與Adobe Commerce版本相容。
若要更新Adobe Commerce 2.4.4版和更新版本的composer.json
檔案:
-
將下列
allow-plugins
新增至config
區段:code language-json "config": { "allow-plugins": { "dealerdirect/phpcodesniffer-composer-installer": true, "laminas/laminas-dependency-plugin": true, "magento/*": true } },
-
將下列外掛程式新增至
require
區段:code language-json "require": { "magento/composer-root-update-plugin": "^2.0.3" },
-
將下列元件新增至
extra:component_paths
區段:code language-json "extra": { "component_paths": { "tinymce/tinymce": "lib/web/tiny_mce_5" }, },
-
儲存檔案。 尚未認可或推送變更至您的分支。
-
繼續進行升級程式。
專案備份
建議您先建立專案的備份,再進行升級。 使用下列步驟來備份您的整合、測試和生產環境。
若要備份您的整合環境資料庫和程式碼:
-
建立遠端資料庫的本機備份。
code language-bash magento-cloud db:dump
note note NOTE magento-cloud db:dump
命令執行帶有--single-transaction
旗標的mysqldump命令,可讓您備份資料庫而不鎖定資料表。 -
備份程式碼和媒體。
code language-bash php bin/magento setup:backup --code [--media]
如果您有大量靜態檔案已經在原始檔控制中,您可以選擇忽略
[--media]
。
若要在部署之前備份您的預備或生產環境資料庫:
應用程式升級
請先檢閱服務版本資訊,瞭解最新的軟體版本需求,然後再升級您的應用程式。
若要升級應用程式版本:
-
在本機工作站上,變更至專案目錄。
-
使用版本限制語法設定升級版本。
code language-bash composer require "magento/magento-cloud-metapackage":">=CURRENT_VERSION <NEXT_VERSION" --no-update
note note NOTE 您必須使用版本限制語法才能成功更新 ece-tools
封裝。 您可以在用於升級的應用程式範本版本之composer.json
檔案中找到版本限制。 -
更新專案。
code language-bash composer update
-
檢閱目前套用的修正程式:
-
如果
m2-hotfixes
目錄中有安裝任何修補程式,請提交Adobe Commerce支援票證,並與Adobe Commerce支援人員合作,確認哪些修補程式仍可套用至新版本。 從m2-hotfixes
目錄移除不適用的修補程式。 -
如果
.magento.env.yaml
檔案中套用了任何[品質修補程式],請確認它們是否仍可套用至新版本。 從.magento.env.yaml
檔案的QUALITY_PATCHES
區段中移除不適用的修補程式。
方法1: 驗證Quality Patches發行說明中的適用版本
方法2: 檢視可用的修補程式和狀態
方法3: 搜尋修補程式
-
-
新增、提交和推送程式碼變更。
code language-bash git add -A
code language-bash git commit -m "Upgrade"
code language-bash git push origin <branch-name>
因為Composer封送基底套件的方式,所以需要
git add -A
才能將所有變更的檔案新增到原始檔控制中。 從基底封裝(magento/magento2-base
和magento/magento2-ee-base
)將composer install
和composer update
封送檔案合併到封裝根目錄中。Composer封送處理的檔案屬於新版Adobe Commerce,以便覆寫這些相同檔案的過時版本。 目前,Adobe Commerce中已停用封送處理,因此您必須將封送處理檔案新增至原始檔控制。
-
等待部署完成。
-
使用SSH登入並檢查版本,在整合、測試或生產環境中驗證升級。
code language-bash php bin/magento --version
建立config.php檔案
如組態管理中所述,升級之後,您必須建立更新的config.php
檔案。 透過您整合環境中的「管理員」完成任何其他設定變更。
若要建立系統特定的組態檔:
-
從終端機,使用SSH命令產生環境的
/app/etc/config.php
檔案。code language-bash ssh <SSH-URL> "<Command>"
例如,對於Pro,若要在
integration
分支上執行scd-dump
:code language-bash ssh <project-id-integration>@ssh.us.magentosite.cloud "php vendor/bin/ece-tools config:dump"
-
使用
rsync
或scp
將config.php
檔案傳輸至您的本機工作站。 您只能將此檔案新增至本機分支。code language-bash rsync <SSH-URL>:app/etc/config.php ./app/etc/config.php
-
新增、提交和推送程式碼變更。
code language-bash git add app/etc/config.php && git commit -m "Add system-specific configuration" && git push origin master
這會產生具有模組清單和組態設定的更新
/app/etc/config.php
檔案。
config.php
檔案。 將此檔案新增到您的程式碼後,您應該 不 刪除它。 如果您必須移除或編輯設定,請手動編輯檔案。升級擴充功能
檢閱Marketplace或其他公司網站中的協力廠商擴充功能和模組頁面,並確認對雲端基礎結構上的Adobe Commerce和Adobe Commerce的支援。 如果您必須升級任何協力廠商擴充功能和模組,Adobe建議您在停用擴充功能的情況下,使用新的整合分支。
若要驗證並升級您的擴充功能:
-
在您的本機工作站上建立分支。
-
視需要停用您的擴充功能。
-
可用時,下載擴充功能升級。
-
安裝第三方檔案記錄的升級。
-
啟用並測試擴充功能。
-
新增、提交程式碼變更,並將其推播至遠端。
-
推送至並在您的整合環境中測試。
-
推送至測試環境,以便在預先生產環境中測試。
Adobe強烈建議您在網站啟動程式中 之前升級您的生產環境,包括升級的擴充功能。
疑難排解升級
如果升級失敗,您會在瀏覽器中收到一則錯誤訊息,指出您無法存取店面或管理面板:
There has been an error processing your request
Exception printing is disabled by default for security reasons.
Error log record number: <error-number>
若要解決錯誤:
-
在本機工作站上,變更至專案目錄。
-
使用SSH登入遠端環境。
code language-bash magento-cloud ssh
-
開啟
./app/var/report/<error number>
檔案。 -
檢查記錄並判斷問題的來源。
-
新增、提交和推送程式碼變更。
code language-bash git add -A && git commit -m "Fixed deployment failure" && git push origin <branch-name>