我实际上找到了一种方法来解决这个问题。我在dev.to上读到的关于此的文章已结束
我需要做一些事情来实现这一点。
首先,不要在构建时设置 containerRegistry。
- task: Docker@2
displayName: Build Docker Image
inputs:
repository: $(imageName)
command: build
dockerfile: '**/Dockerfile'
buildContext: 'HopefulMommaDesignsAPI'
tags: $(Build.BuildId)
这样做的原因是,如果您设置容器注册表,那么至少使用 ACR,它会将 ACR URL 作为 docker 映像名称的前缀。但是,在 Azure DevOps 中执行此操作时,该 URL 会被加密。这没有什么问题,但是当您列出图像时会引起混乱,因为它会显示为 ***/ImageName。
其次,将图像保存为工件暂存目录中的 TAR 文件。
- task: Docker@2
displayName: 'Save image to TAR'
inputs:
repository: '$(imageName)'
command: save
arguments: '--output $(build.artifactstagingdirectory)/$(imageName).image.tar $(imageName):$(Build.BuildId)'
addPipelineData: false
当您发布构建时,这将包括 .tar 文件。
接下来的步骤是在部署作业期间。
下载构建工件并部署 ARM 模板后,您需要从 .tar 文件加载 docker 映像。
- task: Docker@2
displayName: 'Load Image from Tar'
inputs:
command: load
arguments: '--input $(build.artifactstagingdirectory)/$(buildArtifactName)/$(imageName).image.tar'
现在已经加载了 docker 映像,您需要重新标记映像并发布它。
- task: Docker@2
displayName: 'ReTag Image with ACR URL - BuildId'
inputs:
containerRegistry: 'Hopeful Momma Designs ACR'
repository: $(imageName)
command: tag
arguments: '$(imageName):$(Build.BuildId) $(containerRegistryUrl)/$(imageName):$(Build.BuildId)'
- task: Docker@2
displayName: 'ReTag Image with ACR URL - latest'
inputs:
containerRegistry: 'Hopeful Momma Designs ACR'
repository: $(imageName)
command: tag
arguments: '$(imageName):$(Build.BuildId) $(containerRegistryUrl)/$(imageName):latest'
- task: Docker@2
displayName: push
inputs:
containerRegistry: 'Hopeful Momma Designs ACR'
repository: $(imageName)
command: push
dockerfile: '**/Dockerfile'
buildContext: 'HopefulMommaDesignsAPI'
tags: |
$(Build.BuildId)
latest
注意:如果您的 Azure 容器注册表是 ARM 模板的一部分,则包含 containerRegistry 的 Docker 命令将失败,因为您必须手动设置从 Azure DevOps 到 Azure 容器注册表的服务连接,然后才能在 YAML 中引用它文件作为 containerRegistry。
这对我来说没什么大不了的,因为无论如何我通常都会分段处理管道。我将确保构建工作,然后我将确保 ARM 模板工作,然后我将确保 docker 图像推送到 ACR。如果您要从头开始重建环境,只需注释掉 ARM 模板步骤之后的部署步骤即可部署基础架构,然后取消注释其余步骤。这不是最干净的解决方案,但我更喜欢它而不是仅仅为了部署基础设施而使用单独的管道。