DockerCompose@0 - Docker Compose v0 工作
建置、推送或執行多容器 Docker 應用程式。 將此工作與 Docker 或 Azure Container Registry 搭配使用。
這很重要
DockerCompose@0工作已被取代。 工作使用 docker-compose v1,自 2023 年 7 月起不再收到更新。 若要使用 docker compose v2,請使用 DockerCompose@1 工作。 如需詳細資訊,請參閱 DockerCompose@0 在 v1 相容性模式中使用 Docker Compose v2。
建置、推送或執行多容器 Docker 應用程式。 將此工作與 Docker 或 Azure Container Registry 搭配使用。
語法
# Docker Compose v0
# Build, push or run multi-container Docker applications. Task can be used with Docker or Azure Container registry.
- task: DockerCompose@0
inputs:
containerregistrytype: 'Azure Container Registry' # 'Azure Container Registry' | 'Container Registry'. Required. Container Registry Type. Default: Azure Container Registry.
#dockerRegistryEndpoint: # string. Optional. Use when containerregistrytype = Container Registry. Docker Registry Service Connection.
#azureSubscription: # string. Alias: azureSubscriptionEndpoint. Optional. Use when containerregistrytype = Azure Container Registry. Azure subscription.
#azureContainerRegistry: # string. Optional. Use when containerregistrytype = Azure Container Registry. Azure Container Registry.
dockerComposeFile: '**/docker-compose.yml' # string. Required. Docker Compose File. Default: **/docker-compose.yml.
#additionalDockerComposeFiles: # string. Additional Docker Compose Files.
#dockerComposeFileArgs: # string. Environment Variables.
#projectName: '$(Build.Repository.Name)' # string. Project Name. Default: $(Build.Repository.Name).
#qualifyImageNames: true # boolean. Qualify Image Names. Default: true.
action: 'Run a Docker Compose command' # 'Build services' | 'Push services' | 'Run services' | 'Run a specific service' | 'Lock services' | 'Write service image digests' | 'Combine configuration' | 'Run a Docker Compose command'. Required. Action. Default: Run a Docker Compose command.
#additionalImageTags: # string. Optional. Use when action = Build services || action = Push services. Additional Image Tags.
#includeSourceTags: false # boolean. Optional. Use when action = Build services || action = Push services. Include Source Tags. Default: false.
#includeLatestTag: false # boolean. Optional. Use when action = Build services || action = Push services. Include Latest Tag. Default: false.
#buildImages: true # boolean. Optional. Use when action = Run services. Build Images. Default: true.
#serviceName: # string. Required when action = Run a specific service. Service Name.
#containerName: # string. Optional. Use when action = Run a specific service. Container Name.
#ports: # string. Optional. Use when action = Run a specific service. Ports.
#workingDirectory: # string. Alias: workDir. Optional. Use when action = Run a specific service. Working Directory.
#entrypoint: # string. Optional. Use when action = Run a specific service. Entry Point Override.
#containerCommand: # string. Optional. Use when action = Run a specific service. Command.
#detached: true # boolean. Optional. Use when action = Run services || action = Run a specific service. Run in Background. Default: true.
#abortOnContainerExit: true # boolean. Optional. Use when action = Run services && detached == false. Abort on Container Exit. Default: true.
#imageDigestComposeFile: '$(Build.StagingDirectory)/docker-compose.images.yml' # string. Required when action = Write service image digests. Image Digest Compose File. Default: $(Build.StagingDirectory)/docker-compose.images.yml.
#removeBuildOptions: false # boolean. Optional. Use when action = Lock services || action = Combine configuration. Remove Build Options. Default: false.
#baseResolveDirectory: # string. Optional. Use when action = Lock services || action = Combine configuration. Base Resolve Directory.
#outputDockerComposeFile: '$(Build.StagingDirectory)/docker-compose.yml' # string. Required when action = Lock services || action = Combine configuration. Output Docker Compose File. Default: $(Build.StagingDirectory)/docker-compose.yml.
#dockerComposeCommand: # string. Required when action = Run a Docker Compose command. Command.
#arguments: # string. Optional. Use when action != Lock services && action != Combine configuration && action != Write service image digests. Arguments.
# Advanced Options
#dockerHostEndpoint: # string. Docker Host Service Connection.
#nopIfNoDockerComposeFile: false # boolean. No-op if no Docker Compose File. Default: false.
#requireAdditionalDockerComposeFiles: false # boolean. Require Additional Docker Compose Files. Default: false.
#currentWorkingDirectory: '$(System.DefaultWorkingDirectory)' # string. Alias: cwd. Working Directory. Default: $(System.DefaultWorkingDirectory).
#dockerComposePath: # string. Docker Compose executable Path.
# Docker Compose v0
# Build, push or run multi-container Docker applications. Task can be used with Docker or Azure Container registry.
- task: DockerCompose@0
inputs:
containerregistrytype: 'Azure Container Registry' # 'Azure Container Registry' | 'Container Registry'. Required. Container Registry Type. Default: Azure Container Registry.
#dockerRegistryEndpoint: # string. Optional. Use when containerregistrytype = Container Registry. Docker Registry Service Connection.
#azureSubscription: # string. Alias: azureSubscriptionEndpoint. Optional. Use when containerregistrytype = Azure Container Registry. Azure subscription.
#azureContainerRegistry: # string. Optional. Use when containerregistrytype = Azure Container Registry. Azure Container Registry.
dockerComposeFile: '**/docker-compose.yml' # string. Required. Docker Compose File. Default: **/docker-compose.yml.
#additionalDockerComposeFiles: # string. Additional Docker Compose Files.
#dockerComposeFileArgs: # string. Environment Variables.
#projectName: '$(Build.Repository.Name)' # string. Project Name. Default: $(Build.Repository.Name).
#qualifyImageNames: true # boolean. Qualify Image Names. Default: true.
action: 'Run a Docker Compose command' # 'Build services' | 'Push services' | 'Run services' | 'Run a specific service' | 'Lock services' | 'Write service image digests' | 'Combine configuration' | 'Run a Docker Compose command'. Required. Action. Default: Run a Docker Compose command.
#additionalImageTags: # string. Optional. Use when action = Build services || action = Push services. Additional Image Tags.
#includeSourceTags: false # boolean. Optional. Use when action = Build services || action = Push services. Include Source Tags. Default: false.
#includeLatestTag: false # boolean. Optional. Use when action = Build services || action = Push services. Include Latest Tag. Default: false.
#buildImages: true # boolean. Optional. Use when action = Run services. Build Images. Default: true.
#serviceName: # string. Required when action = Run a specific service. Service Name.
#containerName: # string. Optional. Use when action = Run a specific service. Container Name.
#ports: # string. Optional. Use when action = Run a specific service. Ports.
#workingDirectory: # string. Alias: workDir. Optional. Use when action = Run a specific service. Working Directory.
#entrypoint: # string. Optional. Use when action = Run a specific service. Entry Point Override.
#containerCommand: # string. Optional. Use when action = Run a specific service. Command.
#detached: true # boolean. Optional. Use when action = Run services || action = Run a specific service. Run in Background. Default: true.
#abortOnContainerExit: true # boolean. Optional. Use when action = Run services && detached == false. Abort on Container Exit. Default: true.
#imageDigestComposeFile: '$(Build.StagingDirectory)/docker-compose.images.yml' # string. Required when action = Write service image digests. Image Digest Compose File. Default: $(Build.StagingDirectory)/docker-compose.images.yml.
#removeBuildOptions: false # boolean. Optional. Use when action = Lock services || action = Combine configuration. Remove Build Options. Default: false.
#baseResolveDirectory: # string. Optional. Use when action = Lock services || action = Combine configuration. Base Resolve Directory.
#outputDockerComposeFile: '$(Build.StagingDirectory)/docker-compose.yml' # string. Required when action = Lock services || action = Combine configuration. Output Docker Compose File. Default: $(Build.StagingDirectory)/docker-compose.yml.
#dockerComposeCommand: # string. Required when action = Run a Docker Compose command. Command.
#arguments: # string. Optional. Use when action != Lock services && action != Combine configuration && action != Write service image digests. Arguments.
# Advanced Options
#dockerHostEndpoint: # string. Docker Host Service Connection.
#nopIfNoDockerComposeFile: false # boolean. No-op if no Docker Compose File. Default: false.
#requireAdditionalDockerComposeFiles: false # boolean. Require Additional Docker Compose Files. Default: false.
#currentWorkingDirectory: '$(System.DefaultWorkingDirectory)' # string. Alias: cwd. Working Directory. Default: $(System.DefaultWorkingDirectory).
輸入
containerregistrytype
-
Container Registry 類型
string
。 必須的。 允許的值:Azure Container Registry
、Container Registry
。 預設值:Azure Container Registry
。
如果使用 ACR,則指定 Azure Container Registry 類型。 如果使用任何其他容器登錄,請指定 Container Registry 類型。
dockerRegistryEndpoint
-
Docker Registry Service 連線
string
。 選擇性。
containerregistrytype = Container Registry
時使用 。
指定 Docker 登錄服務連線。 當命令需要使用登錄進行驗證時需要用到。
azureSubscription
-
Azure 訂用帳戶
輸入別名:azureSubscriptionEndpoint
。
string
。 選擇性。
containerregistrytype = Azure Container Registry
時使用 。
指定 Azure 訂用帳戶。 Azure 服務連線的名稱。 若要手動設定連線,請參閱 Azure Resource Manager 服務連線。
azureContainerRegistry
-
Azure Container Registry
string
。 選擇性。
containerregistrytype = Azure Container Registry
時使用 。
指定 Azure Container Registry。
dockerComposeFile
-
Docker Compose 檔案
string
。 必須的。 預設值:**/docker-compose.yml
。
指定主要 Docker Compose 檔案的檔案路徑。
additionalDockerComposeFiles
-
其他 Docker Compose 檔案
string
。
指定與主要 Docker Compose 檔案結合的其他 Docker Compose 檔案。 相對路徑會相對於包含主要 Docker Compose 檔案的目錄解析。 如果找不到指定的檔案,則會忽略它。 在新行上指定每個檔案路徑。
dockerComposeFileArgs
-
環境變數
string
。
指定所設定的任何環境變數。
格式如下:
- 列出新行上每個
name=value
組。 - 使用 YAML 中的
|
運算符來保留新行。
projectName
-
項目名稱
string
。 預設值:$(Build.Repository.Name)
。
指定預設用來命名映像和容器的項目名稱。
qualifyImageNames
-
限定映像名稱
boolean
。 預設值:true
。
根據預設,指定 Docker 登錄服務連線的主機名。
action
-
動作
string
。 必須的。 允許的值:Build services
(建置服務映射)、Push services
(推送服務映射)、Run services
(執行服務映射)、Run a specific service
(執行特定服務映射)、Lock services
(鎖定服務映射)、Write service image digests
、Combine configuration
Run a Docker Compose command
。 預設值:Run a Docker Compose command
。
從允許的值清單中指定 Docker Compose 動作。
additionalImageTags
-
其他影像標記
string
。 選擇性。
action = Build services || action = Push services
時使用 。
指定要建置或推送之 Docker 映像的其他標籤。 您可以指定多個標記,以 \n
行摘要分隔每個標記。
includeSourceTags
-
包含來源標籤
boolean
。 選擇性。
action = Build services || action = Push services
時使用 。 預設值:false
。
指定建置或推送 Docker 映射時的 Git 標記。
includeLatestTag
-
包含最新的標籤
boolean
。 選擇性。
action = Build services || action = Push services
時使用 。 預設值:false
。
指定建置或推送 Docker 映射時,最新的 標記。
buildImages
-
建置映像
boolean
。 選擇性。
action = Run services
時使用 。 預設值:true
。
指定啟動服務容器之前建置映像。
serviceName
-
服務名稱
string
。
action = Run a specific service
時為必要項。
指定您要執行的服務名稱。
containerName
-
容器名稱
string
。 選擇性。
action = Run a specific service
時使用 。
指定您想要使用的服務容器名稱。
ports
-
埠
string
。 選擇性。
action = Run a specific service
時使用 。
指定要發佈至主機之服務容器中的埠。 在新行上新增每個 host-port:container-port
系結。
workingDirectory
-
工作目錄
輸入別名:workDir
。
string
。 選擇性。
action = Run a specific service
時使用 。
指定服務容器的工作目錄。
entrypoint
-
進入點覆寫
string
。 選擇性。
action = Run a specific service
時使用 。
指定服務容器預設進入點的覆寫值。
containerCommand
-
命令
string
。 選擇性。
action = Run a specific service
時使用 。
指定要在服務容器中執行的命令。 例如,如果映像包含簡單的 Python Flask Web 應用程式,您可以指定要啟動 Web 應用程式的 python app.py
。
在背景執行 detached
-
boolean
。 選擇性。
action = Run services || action = Run a specific service
時使用 。 預設值:true
。
指定要在背景中執行的服務容器。
容器結束 abortOnContainerExit
- 中止
boolean
。 選擇性。
action = Run services && detached == false
時使用 。 預設值:true
。
指定任何容器結束時應該停止的所有容器。
imageDigestComposeFile
-
影像摘要撰寫檔案
string
。
action = Write service image digests
時為必要項。 預設值:$(Build.StagingDirectory)/docker-compose.images.yml
。
指定 Docker Compose 檔案的路徑,該檔案會建立並填入每個服務的 Docker 映像的完整映射存放庫摘要。
removeBuildOptions
-
移除建置選項
boolean
。 選擇性。
action = Lock services || action = Combine configuration
時使用 。 預設值:false
。
指定是否應該從輸出 Docker Compose 檔案中移除組建選項。
baseResolveDirectory
-
基底解析目錄
string
。 選擇性。
action = Lock services || action = Combine configuration
時使用 。
指定應該從中解析輸出 Docker Compose 檔案中相對路徑的基底目錄。
outputDockerComposeFile
-
輸出 Docker Compose 檔案
string
。
action = Lock services || action = Combine configuration
時為必要項。 預設值:$(Build.StagingDirectory)/docker-compose.yml
。
指定輸出 Docker Compose 檔案的路徑。
dockerComposeCommand
-
命令
string
。
action = Run a Docker Compose command
時為必要項。
指定要搭配自變數執行的 Docker Compose 命令。 例如,rm --all
移除所有已停止的服務容器。
arguments
-
自變數
string
。 選擇性。
action != Lock services && action != Combine configuration && action != Write service image digests
時使用 。
指定 Docker Compose 命令選項。
範例:針對建置命令,--pull --compress --parallel
。
dockerHostEndpoint
-
Docker 主機服務連線
string
。
指定 Docker 主機服務連線。 預設為代理程式的主機。
如果沒有 Docker Compose 檔案,nopIfNoDockerComposeFile
- No-op
boolean
。 預設值:false
。
指定值,如果 Docker Compose 檔案不存在,則會略過工作。 當工作根據存放庫中 Docker Compose 檔案的存在提供選擇性行為時,這個選項很有用。
requireAdditionalDockerComposeFiles
-
需要額外的 Docker Compose 檔案
boolean
。 預設值:false
。
指定值,如果其他 Docker Compose 檔案不存在,則會產生錯誤。 此選項會覆寫預設行為,如果檔案不存在,則會忽略該檔案。
currentWorkingDirectory
-
工作目錄
輸入別名:cwd
。
string
。 預設值:$(System.DefaultWorkingDirectory)
。
指定 Docker Compose 命令的工作目錄。
dockerComposePath
-
Docker Compose 可執行文件路徑
string
。
指定要判斷是否使用 docker-compose 可執行文件的路徑。
工作控制選項
除了工作輸入之外,所有工作都有控制選項。 如需詳細資訊,請參閱 控制項選項和一般工作屬性。
輸出變數
此工作會定義下列 輸出變數,您可以在下游步驟、作業和階段中取用這些變數。
DockerComposeOutput
包含命令輸出之檔案的路徑。 這可以包含多個檔案路徑(以換行符分隔),例如 dockerComposeRun 命令(一個用於執行,另一個用於關閉)、dockerPush(每個推送的映射各一個)、dockerBuild(組建本身和所有標記命令)和 dockerDigest(每個提取的映射各一個)。 其他命令只會輸出一個檔案。
備註
這很重要
DockerCompose@0工作已被取代。 工作使用 docker-compose v1,自 2023 年 7 月起不再收到更新。 若要使用 docker compose v2,請使用 DockerCompose@1 工作。 如需詳細資訊,請參閱 DockerCompose@0 在 v1 相容性模式中使用 Docker Compose v2。
使用此工作來建置、推送或執行多容器 Docker 應用程式。 搭配 Docker 登錄或 Azure Container Registry 使用此工作。
範例
- Azure Container Registry
- 其他容器登錄
- 建置服務映射
- 推送服務映像
- 執行服務映像
- 執行特定服務映像
- 鎖定服務映像
- 寫入服務映射摘要
- 合併組態
- 執行 Docker Compose 命令
Azure 容器註冊表 (Azure Container Registry)
此 YAML 範例會指定 Azure Container Registry 的輸入:
variables:
azureContainerRegistry: Contoso.azurecr.io
azureSubscriptionEndpoint: Contoso
steps:
- task: DockerCompose@0
displayName: Container registry login
inputs:
containerregistrytype: Azure Container Registry
azureSubscriptionEndpoint: $(azureSubscriptionEndpoint)
azureContainerRegistry: $(azureContainerRegistry)
其他容器登錄
使用 ACR 以外的任何容器登錄時,需要 containerregistrytype 值。 在此情況下,請使用 containerregistrytype: Container Registry
。
此 YAML 範例會指定 ACR 以外的容器登錄,其中 Contoso 是容器登錄的 Docker 登錄服務連線名稱:
- task: DockerCompose@0
displayName: Container registry login
inputs:
containerregistrytype: Container Registry
dockerRegistryEndpoint: Contoso
建置服務映像
此 YAML 範例會根據與 Azure Container Registry 相關的輸入,建置映射名稱限定的映像:
- task: DockerCompose@0
displayName: Build services
inputs:
action: Build services
azureSubscriptionEndpoint: $(azureSubscriptionEndpoint)
azureContainerRegistry: $(azureContainerRegistry)
dockerComposeFile: docker-compose.yml
projectName: $(Build.Repository.Name)
qualifyImageNames: true
additionalImageTags: $(Build.BuildId)
dockerComposeFileArgs: |
firstArg=$(firstArg)
secondArg=$(secondArg)
推送服務映像
此 YAML 範例會將映像推送至容器登錄:
- task: DockerCompose@0
displayName: Push services
inputs:
action: Push services
azureSubscriptionEndpoint: $(azureSubscriptionEndpoint)
azureContainerRegistry: $(azureContainerRegistry)
dockerComposeFile: docker-compose.yml
projectName: $(Build.Repository.Name)
qualifyImageNames: true
additionalImageTags: $(Build.BuildId)
執行服務映像
此 YAML 範例會執行服務:
- task: DockerCompose@0
displayName: Run services
inputs:
action: Run services
azureSubscriptionEndpoint: $(azureSubscriptionEndpoint)
azureContainerRegistry: $(azureContainerRegistry)
dockerComposeFile: docker-compose.ci.build.yml
projectName: $(Build.Repository.Name)
qualifyImageNames: true
buildImages: true
abortOnContainerExit: true
detached: true
執行特定服務映像
此 YAML 範例會執行特定服務:
- task: DockerCompose@0
displayName: Run a specific service
inputs:
action: Run a specific service
azureSubscriptionEndpoint: $(azureSubscriptionEndpoint)
azureContainerRegistry: $(azureContainerRegistry)
dockerComposeFile: docker-compose.yml
projectName: $(Build.Repository.Name)
qualifyImageNames: true
serviceName: myhealth.web
ports: 80:80
detached: true
鎖定服務映像
此 YAML 範例會鎖定服務:
- task: DockerCompose@0
displayName: Lock services
inputs:
action: Lock services
azureSubscriptionEndpoint: $(azureSubscriptionEndpoint)
azureContainerRegistry: $(azureContainerRegistry)
dockerComposeFile: docker-compose.yml
projectName: $(Build.Repository.Name)
qualifyImageNames: true
outputDockerComposeFile: $(Build.StagingDirectory)/docker-compose.yml
撰寫服務映像摘要
此 YAML 範例會撰寫服務映像摘要:
- task: DockerCompose@0
displayName: Write service image digests
inputs:
action: Write service image digests
azureSubscriptionEndpoint: $(azureSubscriptionEndpoint)
azureContainerRegistry: $(azureContainerRegistry)
dockerComposeFile: docker-compose.yml
projectName: $(Build.Repository.Name)
qualifyImageNames: true
imageDigestComposeFile: $(Build.StagingDirectory)/docker-compose.images.yml
合併組態
此 YAML 範例結合了組態:
- task: DockerCompose@0
displayName: Combine configuration
inputs:
action: Combine configuration
azureSubscriptionEndpoint: $(azureSubscriptionEndpoint)
azureContainerRegistry: $(azureContainerRegistry)
dockerComposeFile: docker-compose.yml
additionalDockerComposeFiles: docker-compose.override.yml
projectName: $(Build.Repository.Name)
qualifyImageNames: true
outputDockerComposeFile: $(Build.StagingDirectory)/docker-compose.yml
執行 Docker Compose 命令
此 YAML 範例會執行 docker Compose 命令:
- task: DockerCompose@0
displayName: Run a Docker Compose command
inputs:
action: Run a Docker Compose command
azureSubscriptionEndpoint: $(azureSubscriptionEndpoint)
azureContainerRegistry: $(azureContainerRegistry)
dockerComposeFile: docker-compose.yml
projectName: $(Build.Repository.Name)
qualifyImageNames: true
dockerComposeCommand: rm
需求
要求 | 說明 |
---|---|
管線類型 | YAML、傳統組建、傳統版本 |
執行於 | Agent、DeploymentGroup |
需求 | 沒有 |
功能 | 此工作不符合作業中後續工作的任何需求。 |
命令限制 | 任意 |
Settable 變數 | 任意 |
代理程式版本 | 所有支援的代理程式版本。 |
工作類別 | 建造 |