假设有一个 docker 镜像,有人对其进行了更改,然后将其推送到 docker 存储库。然后我拉下图像。有没有办法获取该图像并运行上一层的容器?运行更改之前的版本。
如果我运行 docker History 它将看起来像这样:
docker history imagename:tag
IMAGE CREATED CREATED BY SIZE COMMENT
3e23a5875458 8 days ago /bin/sh -c #(nop) ENV LC_ALL=C.UTF-8 0 B
<missing> 8 days ago /bin/sh -c dpkg-reconfigure locales && loc 1.245 MB
<missing> 8 days ago /bin/sh -c apt-get update && apt-get install 338.3 MB
<missing> 6 weeks ago /bin/sh -c #(nop) ADD jessie.tar.xz in / 121 MB
<missing> 6 weeks ago /bin/sh -c #(nop) MAINTAINER ssss <ad 0 B
<missing> 9 months ago 0 B
如果我找到一种方法来标记或识别图像的先前层,似乎我可以运行早期版本。
您可以通过标记图像的构建层(如果您有权访问它们)来实现。如上所述here.
在您的情况下,可能发生的情况是,从版本 v1.10.0 开始,他们改变了docker 引擎处理内容可寻址性。这个问题正在被热烈讨论here.
这意味着您将无权访问构建层,除非您在当前计算机中构建此映像或通过组合导出和加载:
docker save imagename build-layer1 build-layer2 build-layer3 > image-caching.tar
docker load -i image-caching.tar
用户在我之前提到的讨论中发布了一种保存缓存的便捷方法:
docker save imagename $(sudo docker history -q imagename | tail -n +2 | grep -v \<missing\> | tr '\n' ' ') > image-caching.tar
这应该收集给定图像的所有构建层并将它们保存到缓存 tar 文件中。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)