Docker学习重点(5)~Docker镜像原理、commit提

2022-05-16  本文已影响0人  一乐乐

一、Docker镜像

1、镜像是什么

docker镜像是一个特殊的文件系统(实际上由一层一层的文件系统UnionFS组成),除了提供容器运行时所需的程序、库、资源、配置等文件外,还包含了一些为运行时准备的一些配置参数(如匿名卷、环境变量、用户等);镜像不包含任何动态数据,其内容在构建之后也不会被改变。

所有的应用,直接打包docker镜像,就可以直接跑起来!

2、如何得到镜像:


二、镜像原理

1、Docker镜像加载原理:

■ docker的镜像实际上由一层一层的文件系统组成,这种层级的文件系统UnionFS。

bootfs(boot file system):包含boot加载器(bootloader)和内核(kernel)通过boot启动器引导加载内核。

Linux刚启动时会加载bootfs文件系统,在Docker镜像的最底层是bootfs。这一层与我们典型的Linux/Unix系统是一样的,包含boot加载器和内核。

当boot加载完成之后整个内核就都在内存中了,此时内存的使用权已由bootfs转交给内核,此时系统也会卸载bootfs。

rootfs(root file system),在bootfs上层。

包含典型Linux系统中的/dev,/proc,/bin,/etc等标准目录和文件。rootfs就是操作系统的发行版,比如Ubuntu,Centos等等。

图片.png

● 平时我们安装进虚拟机的CentOS都是好几个G,为什么Docker这里才200M?

对于一个精简的OS,rootfs可以很小,只需要包含最基本的命令,工具和程序库就可以了,因为底层直接用Host的kernel,自己只需要提供rootfs就可以了,由此可见对于不同的linux发行版,bootfs基本是一致的,rootfs会有差别,因此不同的发行版可以公用bootfs.

2、分层理解:

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

图片.png 图片.png 图片.png

特点

Docker镜像都是只读的,当容器启动时,一个新的可写层被加载到镜像的顶部!这一层就是我们通常说的容器层,容器之下的都叫镜像层!


三、commit提交镜像

1、实战测试commit tomcat镜像

(1)启动一个默认的tomcat

(2)发现这个默认的tomcat 是没有webapps应用,镜像的原因,官方的镜像默认 webapps下面是没有文件的!

(3)我自己拷贝进去了基本的文件

(4)将我们操作过的容器通过commit提交为一个镜像!我们以后就使用我们修改过的镜像即可

docker images
docker run -it -p 8080:8080 tomcat
图片.png
docker commit -a="paidaxing" -m="add webapps app" 当前容器的id tomcat02:1.0
图片.png

如果想保存当前容器的状态,可以通过commit提交,获得一个(新)镜像

好比我们以前学习VM的时候的快照


☺ 参考来源:
狂神的B站视频《【狂神说Java】Docker最新超详细版教程通俗易懂》 https://www.bilibili.com/video/BV1og4y1q7M4


如果本文对你有帮助的话记得给一乐点个赞哦,感谢!

上一篇下一篇

猜你喜欢

热点阅读