众所周知,标记是可变的,摘要是不可变的。在需要确保在服务的整个生命周期中使用相同的精确映像的许多情况下,最好使用摘要。它被认为是生产环境的最佳实践(请参见this和this)。
摘要的问题是,尽管摘要不可变且有用,但人类无法理解。并且所有示例都使用 摘要 或 标签。但是实践表明,您可以同时使用两者。只是标签被省略了。
例如:
docker run --rm k8s.gcr.io/pause-amd64:3.1@sha256:59eec8837a4d942cc19a52b8c09ea75121acc38114a2c68b98983ce9356b8610
kubectl create deployment pause --image k8s.gcr.io/pause-amd64:3.1@sha256:59eec8837a4d942cc19a52b8c09ea75121acc38114a2c68b98983ce9356b8610
使用<image_path>:<tag>@sha256:<digest>
模式安全吗?
好像是absolutely legit。
答案 0 :(得分:1)
是的,当摘要存在时,该标签将被忽略。
您甚至可以组成一个标签,它仍将通过摘要提取图像:
docker image pull k8s.gcr.io/pause-amd64:some-made-up-tag@sha256:59eec8837a4d942cc19a52b8c09ea75121acc38114a2c68b98983ce9356b8610
sha256:59eec8837a4d942cc19a52b8c09ea75121acc38114a2c68b98983ce9356b8610: Pulling from pause-amd64
Digest: sha256:59eec8837a4d942cc19a52b8c09ea75121acc38114a2c68b98983ce9356b8610
Status: Image is up to date for k8s.gcr.io/pause-amd64@sha256:59eec8837a4d942cc19a52b8c09ea75121acc38114a2c68b98983ce9356b8610