docker镜像加速原理
docker镜像加速原理?
docker镜像加速的原理:因为Docker镜像是分层的,因此在加载一个镜像的时候,会按照从底层到高层的顺序依次加载该镜像所需要的镜像层。在加载的过程中,如果当前镜像层已经存在,则会跳过当前镜像层。比如:已经下载过MySQL镜像,现在要下载Tomcat镜像,而这两个镜像都需要CentOS镜像层,那么下载Tomcat镜像的时候,就会跳过下载CentOS镜像层。
Docker镜像实际上是由一层一层文件系统组成,这种层级文件系统就是UnionFS
当用docker run启动这个容器时,实际上在镜像的顶部添加了一个新的可写层。这个可写层也叫容器层。
这里我们通过案例来证明一下,这是我本地已经下载好的镜像包,大家可以看到centos这个镜像包的大小才209M,平时我们安装的虚拟机上的centos都是几个G,这个里为什么200M就可以?这里我们的centos镜像文件只是一个最精简的rootfs版本,与底层系统共用了kernel,所以才200M就可以将一个centos跑起来,对于不同发行版本可能这个大小会略微有所不同。