Docker镜像详解

1. UnionFS(联合文件系统)

  • 联合文件系统(UnionFS)是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下。联合文件系统是 Docker 镜像的基础。镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。

  • 特性:一次同时加载多个文件系统,但从外面看起来只能看到一个文件系统。联合加载会把各层文件系统叠加起来,这样最终的文件系统会包含所有底层的文件和目录。

2. 镜像加载原理

Docker镜像详解

1、Docker的镜像实际由一层一层的文件系统组成:

  • bootfs(boot file system)主要包含bootloader和kernel。bootloader主要是引导加载kernel,完成后整个内核就都在内存中了。此时内存的使用权已由bootfs转交给内核,系统卸载bootfs。可以被不同的Linux发行版公用。

  • rootfs(root file system),包含典型Linux系统中的/dev,/proc,/bin,/etc等标准目录和文件。rootfs就是各种不同操作系统发行版(Ubuntu,Centos等)。因为底层直接用Host的kernel,rootfs只包含最基本的命令,工具和程序就可以了。

2、分层理解

  • 所有的Docker镜像都起始于一个基础镜像层,当进行修改或增加新的内容时,就会在当前镜像层之上,创建新的容器层。

  • 容器在启动时会在镜像最外层上建立一层可读写的容器层(R/W),而镜像层是只读的(R/O)。

3. commit 镜像

编辑容器后提交容器成为一个新镜像

docker commit -m="描述信息" -a="作者" 容器id 目标镜像名:[tag]

【实战测试,提交新的tomcat】

1、启动一个默认的tomcat,官方的镜像默认 webapps 下面是没有文件的!

2、拷贝相应的基本文件

Docker镜像详解

3、提交

Docker镜像详解

4、成功访问到tomcat首页

Docker镜像详解

上一篇:Python如何搜索模块


下一篇:学习爬虫之Scrapy框架学习(八)---Scrapy框架里使用分布式爬虫(Scrapy_redis);分布式实战纵横小说爬取+项目完整源码!