設定manifest.yml
位於Asset compute專案根目錄中的manifest.yml
說明此專案中要部署的所有背景工作。
預設背景工作定義
背景工作被定義為actions
下的Adobe I/O Runtime動作專案,由一組設定組成。
存取其他Adobe I/O整合的工作者必須將annotations -> require-adobe-auth
屬性設定為true
,因為此透過params.auth
物件公開工作者的Adobe I/O認證。 當背景工作呼叫Adobe I/OAPI (例如Adobe Photoshop、Lightroom或Sensei API)時,通常需要此專案,而且每個背景工作可切換。
- 開啟並檢閱自動產生的背景工作
manifest.yml
。 包含多個Asset compute背景工作程式的專案,必須為actions
陣列下的每個背景工作程式定義一個專案。
packages:
__APP_PACKAGE__:
license: Apache-2.0
actions: # the array of workers, since we have a single worker there is only one entry beneath actions
worker: # the auto-generated worker definition
function: actions/worker/index.js # the entry point to the worker
web: 'yes' # as our worker is invoked over HTTP from AEM Author service
runtime: 'nodejs:12' # the target nodejs runtime (only 10 and 12 are supported)
limits:
concurrency: 10
annotations:
require-adobe-auth: true # set to true, to pass through Adobe I/O access token/client id via params.auth in the worker, typically required when the worker calls out to Adobe I/O APIs such as the Adobe Photoshop, Lightroom or Sensei APIs.
定義限制
每個背景工作可以在Adobe I/O Runtime中為其執行內容設定限制。 這些值應該根據工作者的數量、比率、將計算的資產型別,以及執行的工作型別,調整為工作者提供最佳規模。
在設定限制之前,請檢閱Adobe大小調整指南。 asset compute背景工作處理資產時可能會因記憶體不足而導致Adobe I/O Runtime執行終止,因此請確保背景工作的大小適合處理所有候選資產。
- 新增
inputs
區段至新的wknd-asset-compute
動作專案。 這可以調整Asset compute工作程式的整體效能和資源配置。
packages:
__APP_PACKAGE__:
license: Apache-2.0
actions:
worker:
function: actions/worker/index.js
web: 'yes'
runtime: 'nodejs:12'
limits: # Allows for the tuning of the worker's performance
timeout: 60000 # timeout in milliseconds (1 minute)
memorySize: 512 # memory allocated in MB; if the worker offloads heavy computational work to other Web services this number can be reduced
concurrency: 10 # adjust based on expected concurrent processing and timeout
annotations:
require-adobe-auth: true
已完成的manifest.yml
最終manifest.yml
看起來像這樣:
packages:
__APP_PACKAGE__:
license: Apache-2.0
actions:
worker:
function: actions/worker/index.js
web: 'yes'
runtime: 'nodejs:12'
limits:
timeout: 60000 # in ms
memorySize: 512 # in MB
concurrency: 10
annotations:
require-adobe-auth: true
Github上的manifest.yml
Github上的最終.manifest.yml
位於:
正在驗證manifest.yml
更新產生的Asset computemanifest.yml
後,請執行本機開發工具,並確保以更新的manifest.yml
設定成功啟動。
若要啟動Asset compute專案的Asset compute開發工具:
-
在Asset compute專案根目錄中開啟命令列(在VS Code中,這可以直接在IDE中透過「終端機>新終端機」開啟),然後執行命令:
code language-none $ aio app run
-
本機Asset compute開發工具將在您的預設網頁瀏覽器中開啟,網址為 http://localhost:9000。
-
在開發工具初始化時,請觀察命令列輸出和網頁瀏覽器中的錯誤訊息。
-
若要停止Asset compute開發工具,請在執行
aio app run
的視窗中點選Ctrl-C
以終止處理序。