8、Docker 镜像与容器的存储与构建解析

Docker 镜像与容器的存储与构建解析

1. 内容摘要与分发哈希

在 Docker 中,基于文件内容(具体为文件系统层)会生成一个哈希函数,生成的哈希值被称为内容摘要(content digest)。由于内容摘要是文件系统层内容的哈希值,所以当层中的内容发生改变时,内容摘要也需要相应改变。

当执行 docker pull docker run 命令时,内容摘要会作为返回码的一部分。Docker Hub 会发送与镜像清单中定义的内容摘要相同的文件系统层。下载完成后,Docker 守护进程会重新计算哈希值,并验证文件系统层的内容摘要是否与镜像清单中定义的一致,以此保证组成镜像的文件系统层的完整性和真实性,无论这些层存储在 Docker Hub 还是自己的容器注册表中。

然而,在网络中处理文件时,为了提高网络带宽和节省存储空间,会对文件进行压缩。但文件压缩会改变其内容,进而改变内容摘要,这会导致在推送或拉取文件系统层时,哈希验证失败。为解决这个问题,引入了分发哈希(distribution hash)。分发哈希是在文件系统层压缩后生成的,每个用于构建镜像的文件系统层都会被压缩并生成对应的分发哈希,该哈希值会被写入镜像清单。之后,镜像就可以推送到 Docker Hub 或其他容器注册表。

运行 docker inspect 命令时,在 Layers 部分看到的哈希是未压缩层的内容摘要,而镜像清单中 digest 字段的哈希值是压缩后文件系统层的分发哈希。可以使用以下命令查看 SQL Server on Linux

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值