ECR 中的 Docker 镜像标记

AWS*_*nar 3 amazon-ec2 amazon-web-services jenkins docker aws-ecr

我正在使用 Jenkins 在 AWS ECR 中推送 docker 镜像。

在推送图像时,我将标签提供为 $Build_Number.So 在 ECR 存储库中,我有带有 1、2、3、4 等标签的图像。

但是当我尝试使用 Jenkins 作业中的以下命令从 EC2 中提取图像时

       docker pull 944XXX.dkr.ecr.us-east-1.amazonaws.com/repository1:latest
Run Code Online (Sandbox Code Playgroud)

我收到错误,因为没有带有最新标签的图像。

在这里我想拉取最新的图像(带有标签 4)。我不能在这里硬编码标签号,因为 docker pull 命令将自动从 Jenkins 作业运行。那么我可以通过什么方式拉取最新的图像?

Lix*_*Lix 10

我相信这里的正确方法是使用不同的标签两次推送相同的图像。一次推送将包含没有标签的图像,然后第二次推送将是您标记后的相同图像。

请注意,您不必两次构建映像。您只需要发出docker push两次。

ECR 足够“聪明”,可以识别图像摘要没有更改,并且不会尝试实际上传图像两次。在第二次推送时,只有标签会被发送到 ECR。

现在您有一个未标记的版本和一个标记的版本,您可以拉取没有标记规范的:latest图像,您将获得图像。这是对 AWS 文档的引用,他们提到:latest如果用户未发送标签,将添加标签。

流程如下所示:

# Build the image
docker build -f ./Dockerfile -t my-web-app
# Push the untagged image (will become the ":latest")
docker push my-web-app
# Tag the image with your build_number
docker tag my-web-app my-web-app:build_number
# Push the tagged image 
docker push my-web-app:build_number
Run Code Online (Sandbox Code Playgroud)

您现在将能够:

docker pull my-web-app:build_number
docker pull my-web-app
Run Code Online (Sandbox Code Playgroud)

这将导致 2 个相同的图像,只有标签区分它们。


Adi*_*iii 5

@Lix 建议您可以尝试一个解决方案,或者如果您只对最新推送的映像感兴趣,并且无论最新映像的标签是什么,那么您都可以从 AWS-CLI 获取最新映像。

所以你的詹金斯工作命令将是

TAG=$(aws ecr describe-images --output json --repository-name stage/redis --query 'sort_by(imageDetails,& imagePushedAt)[-1].imageTags[0]' | jq . --raw-output)
docker pull 944XXX.dkr.ecr.us-east-1.amazonaws.com/repository1:$TAG
Run Code Online (Sandbox Code Playgroud)

aws-cli-ecr-list-images-get-newest