DockerCompose@0 - Docker Compose v0 任务
生成、推送或运行多容器 Docker 应用程序。 将此任务与 Docker 或 Azure 容器注册表配合使用。
重要
DockerCompose@0任务已弃用。 该任务使用自 2023 年 7 月以来不再接收更新的 docker-compose v1。 若要使用 docker compose v2,请使用 DockerCompose@1 任务。 有关详细信息,请参阅 DockerCompose@0 在 v1 兼容模式下使用 Docker Compose v2。
生成、推送或运行多容器 Docker 应用程序。 将此任务与 Docker 或 Azure 容器注册表配合使用。
语法
# 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
-
容器注册表类型
string
。 必填。 允许的值:Azure Container Registry
、Container Registry
。 默认值:Azure Container Registry
。
如果使用 ACR,则指定 Azure 容器注册表类型。 如果使用任何其他容器注册表,请指定容器注册表类型。
dockerRegistryEndpoint
-
Docker 注册表服务连接
string
。 可选。 当 containerregistrytype = Container Registry
时使用。
指定 Docker 注册表服务连接。 当命令需要使用注册表进行身份验证时是必需的。
azureSubscription
-
Azure 订阅
输入别名:azureSubscriptionEndpoint
。
string
。 可选。 当 containerregistrytype = Azure Container Registry
时使用。
指定 Azure 订阅。 Azure 服务连接的名称。 若要手动设置连接,请参阅 Azure 资源管理器服务连接。
azureContainerRegistry
-
Azure 容器注册表
string
。 可选。 当 containerregistrytype = Azure Container Registry
时使用。
指定 Azure 容器注册表。
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 映像的完整映像存储库摘要的 Docker Compose 文件的路径。
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
- 无作
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任务已弃用。 该任务使用自 2023 年 7 月以来不再接收更新的 docker-compose v1。 若要使用 docker compose v2,请使用 DockerCompose@1 任务。 有关详细信息,请参阅 DockerCompose@0 在 v1 兼容模式下使用 Docker Compose v2。
使用此任务生成、推送或运行多容器 Docker 应用程序。 将此任务与 Docker 注册表或 Azure 容器注册表配合使用。
例子
Azure 容器注册表
此 YAML 示例指定 Azure 容器注册表的输入:
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 容器注册表相关的输入生成映像名称限定的映像:
- 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