GraphQL應用程式伺服器

Commerce GraphQL應用程式伺服器可讓Adobe Commerce維護Commerce GraphQL API請求中的狀態。 GraphQL Application Server (以Swoole擴充功能為基礎)會以具有工作者執行緒的處理程式方式運作,以處理要求處理。 GraphQL Application Server可保留GraphQL API請求中的啟動載入應用程式狀態,藉此增強請求處理和整體產品效能。 API要求會大幅提高效率。

GraphQL Application Server僅適用於Adobe Commerce。 它無法用於Magento Open Source。 對於Cloud Pro專案,您必須提交Adobe Commerce支援票證,才能啟用GraphQL應用程式伺服器。

NOTE
GraphQL Application Server目前與Amazon Simple Storage Service (AWS S3)不相容。 目前將AWS S3用於遠端儲存空間的雲端基礎結構上的Adobe Commerce客戶,在Adobe於2024年稍後發行Hotfix之前,無法使用GraphQL Application Server。

架構

GraphQL Application Server可維護Commerce GraphQL API請求之間的狀態,且無需啟動程式。 藉由跨程式共用應用程式狀態,GraphQL要求可大幅提高效率,最多將回應時間減少30%。

從延遲的角度來看,無共用PHP執行模型是一個挑戰,因為每個請求都需要架構的啟動安裝。 此啟動載入程式包括耗時的工作,例如讀取組態、設定啟動載入程式,以及建立服務類別物件。

將請求處理邏輯轉換為應用程式層級的事件回圈,似乎可解決在企業層級精簡請求處理的挑戰。 此方法可免除在請求執行生命週期期間進行啟動載入的需求。

優點

GraphQL應用程式伺服器可讓Adobe Commerce在連續的Commerce GraphQL API請求之間維持狀態。 跨請求共用應用程式狀態透過最小化處理開銷和最佳化請求處理來增強API請求效率。 因此,GraphQL要求回應時間最多可減少30%。

系統需求

執行GraphQL Application Server需要下列專案:

  • Commerce 2.4.7+版
  • PHP 8.2或更高版本
  • 已安裝Swool PHP擴充功能v5+
  • 根據預期負載提供足夠的RAM和CPU

在雲端基礎結構上啟用和部署

ApplicationServer模組(Magento/ApplicationServer/)啟用GraphQL應用程式伺服器。

啟用Pro專案

NOTE
「應用程式伺服器」是Cloud Pro例項上的選擇加入功能。 若要啟用該功能,請提交支援要求。

在Pro專案上啟用「應用程式伺服器」功能後,請先完成下列步驟,再部署GraphQL Application Server:

  1. 2.4.7-appserver分支使用雲端範本,在雲端基礎結構上部署Adobe Commerce。

  2. 確定您所有的Commerce自訂專案和擴充功能都與GraphQL Application Server 相容

  3. 複製您的Commerce Cloud專案。

  4. 如有必要,請調整'application-server/nginx.conf.sample'檔案中的設定。

  5. 完全註解project_root/.magento.app.yaml檔案中的作用中'web'區段。

  6. 取消註解project_root/.magento.app.yaml檔案中包含GraphQL應用程式伺服器start命令的以下'web'區段設定。

    code language-yaml
    web:
        upstream:
            socket_family: tcp
            protocol: http
        commands:
            start: ./application-server/start.sh > var/log/application-server-status.log 2>&1
    
  7. 執行下列命令,確定/application-server/start.sh是可執行的命令:

    code language-bash
    chmod +x application-server/start.sh
    
  8. 使用以下命令將更新的檔案新增到Git索引:

    code language-bash
    git add -f .magento.app.yaml application-server/*
    
  9. 使用此命令提交您的變更:

    code language-bash
    git commit -m "AppServer Enabled"
    

部署Pro專案

完成啟用步驟後,將變更推送至您的Git存放庫以部署GraphQL應用程式伺服器:

git push

啟用入門專案

在入門專案上部署GraphQL Application Server前,請先完成下列步驟:

  1. 2.4.7-appserver分支使用雲端範本,在雲端基礎結構上部署Adobe Commerce。

  2. 確認您所有的Commerce自訂專案和擴充功能都與GraphQL Application Server相容。

  3. 確認已為您的執行個體設定CRYPT_KEY環境變數。 您可以在Cloud Console上檢查此變數的狀態。

  4. 複製您的Commerce Cloud專案。

  5. application-server/.magento/.magento.app.yaml.sample重新命名為application-server/.magento/.magento.app.yaml,並視需要調整.magento.app.yaml中的設定。

  6. 取消註解project_root/.magento/routes.yaml檔案中的下列路由設定,將/graphql流量重新導向至GraphQL應用程式伺服器。

    code language-yaml
    "http://{all}/graphql":
        type: upstream
        upstream: "application-server:http"
    
  7. 將更新的檔案新增至Git索引:

    code language-bash
    git add -f .magento/routes.yaml application-server/.magento/*
    
  8. 提交您的變更:

    code language-bash
    git commit -m "AppServer Enabled"
    
NOTE
確定您的根.magento.app.yaml檔案中的所有自訂設定都已適當地移轉至application-server/.magento/.magento.app.yaml檔案。 將application-server/.magento/.magento.app.yaml檔案新增至專案後,除了根.magento.app.yaml檔案之外,您還應維護該檔案。 例如,如果您需要設定RabbitMQ服務管理Web屬性,您也應該將相同的設定新增到application-server/.magento/.magento.app.yaml

部署入門專案

完成啟用步驟後,將變更推送至您的Git存放庫以部署GraphQL應用程式伺服器:

git push

驗證雲端專案是否啟用

  1. 對您的執行個體執行GraphQL查詢或突變,以確認graphql端點可存取。 例如:

    code language-none
    mutation {
     createEmptyCart
    }
    

    預期的回應應類似於以下範例:

    code language-json
    {
     "data": {
         "createEmptyCart": "HLATPzcLw5ylDf76IC92nxdO2hXSXOrv"
         }
     }
    
  2. 使用SSH存取您的雲端例項。 project_root/var/log/application-server.log應該包含每個GraphQL要求的新記錄記錄。

  3. 您也可以執行下列命令,檢查GraphQL Application Server是否正在執行:

    code language-bash
    ps aux|grep php
    

    您應該會看到含有多個執行緒的bin/magento server:run處理序。

如果這些驗證步驟成功,GraphQL Application Server就會執行並提供/graphql要求。

啟用內部部署專案

ApplicationServer模組(Magento/ApplicationServer/)可為GraphQL API啟用GraphQL應用程式伺服器。

在本機執行GraphQL Application Server需要安裝Swoole延伸模組,並對部署的Nginx設定檔進行微幅變更。

先決條件

在啟用ApplicationServer模組之前,請先完成下列步驟:

  • 設定Nginx
  • 安裝及設定Swoole v5+擴充功能

設定Nginx

您特定的Commerce部署決定了如何設定Nginx。 一般而言,Nginx組態檔預設名為nginx.conf,並放置在下列其中一個目錄中: /usr/local/nginx/conf/etc/nginx/usr/local/etc/nginx。 如需設定Nginx的詳細資訊,請參閱​ 初學者指南

Nginx設定範例:

location /graphql {
    proxy_set_header Host $http_host;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

    proxy_pass http://127.0.0.1:9501/graphql;
}

安裝和設定Swool

若要在本機執行GraphQL Application Server,請安裝Swoole擴充功能(v5.0或更新版本)。 有多種方式可安裝此擴充功能。

下列程式說明如何在OSX系統上安裝PHP 8.2的Swoole擴充功能。 這是安裝Swoole擴充功能的數種方式之一。

pecl install swoole

在安裝期間,Adobe Commerce會顯示提示以啟用opensslmysqlndsocketshttp2postgres的支援。 輸入yes以取得除postgres以外的所有選項。

驗證Swool安裝

確認擴充功能已成功啟用:

php -m | grep swoole

Swoole安裝的常見錯誤

在Swoole安裝期間發生的任何錯誤通常發生在pecl安裝階段。 典型的錯誤包括遺失openssl.hpcre2.h檔案。 若要解決這些錯誤,請確定這兩個套件已安裝在您的本機系統中。

  • 執行,以檢查openssl的位置:
openssl version -d

這個命令顯示openssl的安裝路徑。

  • 執行,以檢查pcre2的位置:
pcre2-config --prefix

如果命令輸出指出遺失檔案,請使用Homebrew安裝遺失的套件:

brew install openssl
brew install pcre2

解決openssl的問題

若要解決與openssl相關的問題,請執行:

export LDFLAGS="-L/opt/homebrew/etc/openssl@3/lib" export CPPFLAGS="-I/opt/homebrew/etc/openssl@3/include"

確認您使用的是本機dev環境的路徑。

確認解決openssl相關問題

您可以再次執行以下命令,以檢查是否已解決與openssl相關的問題:

pecl install swoole

解決pcre2.h的問題

若要解決與pcre2.h相關的問題,請將pcre2.h路徑同步連結到您安裝的PHP延伸模組目錄。 您安裝的特定版本PHP和pcr2.h決定了您應該使用的指令的特定版本。

執行GraphQL應用程式伺服器

啟動GraphQL應用程式伺服器:

bin/magento server:run

這個指令會在9501上啟動HTTP連線埠。 GraphQL應用程式伺服器啟動後,連線埠9501就會變成所有GraphQL查詢的HTTP Proxy伺服器。

若要確認GraphQL Application Server正在您的部署中執行:

ps aux | grep php

確認GraphQL Application Server正在執行的其他方法包括:

  • 檢查/var/log/application-server.log檔案中是否有與已處理GraphQL要求相關的專案。
  • 嘗試連線到GraphQL Application Server執行所在的HTTP連線埠。 例如: curl -g 'http://localhost:9501/graph

確認正在處理GraphQL請求

GraphQL Application Server將值為graphql_serverX-Backend回應標頭新增至其處理的每個要求。 若要檢查GraphQL應用程式伺服器是否已處理要求,請檢查此回應標頭。

確認擴充功能和自訂相容性

擴充功能開發人員和商家應該先確認其擴充功能和自訂程式碼符合​ 技術准則 ​中所述的准則。

在程式碼評估期間請考量下列准則:

  • 服務類別(也就是提供行為但不提供資料的類別,例如EventManager)不應該有可變狀態。
  • 避免暫時耦合。

停用GraphQL應用程式伺服器

停用GraphQL Application Server的程式會因伺服器是在內部部署或雲端部署中執行而有所不同。

停用GraphQL Application Server (雲端)

  1. 移除您在準備部署期間在AppServer Enabled認可中包含的任何新檔案和任何其他程式碼變更。

  2. 使用此命令確認您的變更:

    code language-bash
    git commit -m "AppServer Disabled"
    
  3. 使用此命令部署這些變更:

    code language-bash
    git push
    

停用GraphQL應用程式伺服器(內部部署)

  1. 請註解您在啟用GraphQL應用程式伺服器時新增的nginx.conf檔案的/graphql區段。
  2. 重新啟動nginx。

此停用GraphQL應用程式伺服器的方法有助於快速測試或比較效能。

確認GraphQL Application Server已停用

若要確認php-fpm正在處理GraphQL要求而非GraphQL應用程式伺服器,請輸入以下命令: ps aux | grep php

停用GraphQL Application Server之後:

  • bin/magento server:run為非作用中。
  • 在GraphQL要求之後,var/log/application-server.log不包含任何專案。

GraphQL Application Server的整合和功能測試

擴充功能開發人員可執行兩項整合測試,以驗證與GraphQL Application Server的擴充功能相容性: GraphQlStateTestResetAfterRequestTest

GraphQlStateTest

GraphQlStateTest會偵測共用物件中不應重複用於多個要求的狀態。

此測試的目的是偵測ObjectManager產生的服務物件中的狀態變更。 此測試會執行兩次相同的GraphQL查詢,並比較第二次查詢前後的服務物件狀態。

GraphQlStateTest失敗和可能的補救

  • 無法新增、略過或篩選清單。 如果您看到有關新增、略過或篩選清單的錯誤,請考慮是否可以向後相容的方式重構類別,以使用具有可變狀態的服務類別之工廠。

  • 類別呈現可變狀態。 如果類別本身呈現可變狀態,請嘗試重寫您的程式碼以規避此狀態。 如果因為效能原因需要可變狀態,則實作ResetAfterRequestInterface並使用_resetState()將物件重設為初始建構狀態。

  • 在初始化訊息 ​之前,不能存取Typed屬性$x。 這類訊息的失敗表示建構函式尚未初始化指定的屬性。 這是暫時耦合的形式,因為物件在初始建構後就無法使用。 即使屬性是私有的,也會發生這種耦合,因為從屬性中擷取資料的收集器正在使用PHP反射特徵。 在這種情況下,請嘗試重構類別以避免暫時耦合併避免可變狀態。 如果該重構無法解決失敗,您可以將屬性型別變更為空型別,以便將其初始化為空值。  如果屬性是陣列,請嘗試將屬性初始化為空陣列。

執行vendor/bin/phpunit -c $(pwd)/dev/tests/integration/phpunit.xml dev/tests/integration/testsuite/Magento/GraphQl/App/GraphQlStateTest.php以執行GraphQlStateTest

ResetAfterRequestTest

ResetAfterRequestTest會尋找所有實作ResetAfterRequestInterface的類別,並驗證_resetState()方法是否會將物件的狀態傳回至ObjectManager建構後所保持的狀態。  此測試會建立具有ObjectManager的服務物件,然後複製該物件,呼叫_resetState(),然後比較兩個物件。 測試未呼叫物件例項化與_resetState()之間的任何方法,因此不會確認重設任何可變狀態。 它確實發現_resetState()中的錯誤或錯字可能會將狀態設定為與原來不同的狀態。

ResetAfterRequestTest失敗和可能的修復

  • 類別的屬性值 ​不一致。 如果此測試失敗,請檢查類別是否已變更,結果是在建構之後物件與呼叫_resetState()方法之後物件具有不同的屬性值。 如果您正在處理的類別不包含_resetState()方法本身,請檢查類別階層中實作它的超類別。

  • 在初始化訊息 ​之前,不能存取Typed屬性$x。 GraphQlStateTest也會發生此問題。

    執行vendor/bin/phpunit -c $(pwd)/dev/tests/integration/phpunit.xml dev/tests/integration/testsuite/Magento/Framework/ObjectManager/ResetAfterRequestTest.php以執行ResetAfterRequestTest

功能測試

部署GraphQL Application Server時,擴充功能開發人員應執行WebAPI功能測試,以及GraphQL的任何自訂自動化或手動功能測試。 這些功能測試可協助開發人員識別潛在的錯誤或相容性問題。

狀態監視器模式

執行功能測試(或手動測試)時,GraphQL Application Server可在啟用--state-monitor mode的情況下執行,以協助尋找無意中重複使用狀態的類別。 正常啟動應用程式伺服器,但新增--state-monitor引數除外。

bin/magento server:run --state-monitor

處理完每個要求後,新檔案會新增至tmp目錄,例如: var/tmp/StateMonitor-thread-output-50-6nmxiK。 完成測試後,這些檔案可以與bin/magento server:state-monitor:aggregate-output命令合併,這會建立兩個合併的檔案,一個在XML,一個在JSON

範例:

/var/workspace/var/tmp/StateMonitor-json-2024-04-10T18:50:39Z-hW0ucN.json
/var/workspace/var/tmp/StateMonitor-junit-2024-04-10T18:50:39Z-oreUco.xml

您可以使用檢視XML或JSON的任何工具來檢查這些檔案,這些工具會顯示GraphQlStateTest等服務物件的修改屬性。 --state-monitor模式使用與GraphQlStateTest相同的略過清單和篩選清單。

NOTE
請勿在生產環境中使用--state-monitor模式。 它僅供開發和測試使用。 它會建立許多輸出檔案,而且執行速度比正常慢。
NOTE
由於PHP記憶體回收行程發生錯誤,--state-monitor與PHP版本8.3.0 - 8.3.4不相容。 如果您使用PHP 8.3,您必須升級至8.3.5或更新版本才能使用此功能。
recommendation-more-help
c0c5bbed-4957-4162-81bc-120c837a1894