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


一、Docker镜像

1、镜像是什么

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

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

2、如何得到镜像:

  • 从远程仓库下载
  • 自己制作一个镜像 DockerFile
  • 拷贝



二、镜像原理

1、Docker镜像加载原理:

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

  • 文件系统主要包括:bootfsrootfs

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等等。


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

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

  • 这就是为什么说虚拟机是分钟级别的,容器是秒级的。

2、分层理解:

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

  • 举例,假如基于Ubuntu Linux 16.04创建一个新的镜像,这就是新镜像的第一层;如果在该镜像中添加Python包,就会在基础镜像层之上创建第二个镜像层;如果继续添加一个安全补丁,就会创建第三个镜像层。

  • 在外部看来整个镜像只有6个文件,这是因为最上层中的文件7是文件5的一个更新版本。

特点

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

  • 一开始pull的是一层(只读),增加操作,例如run,新的一层(操作),然后打包成一个新的镜像。



三、commit提交镜像

  • 如何提交一个自己的镜像

    # commit提交容器成为一个新的副本
    docker commit -m="提交的描述信息" -a="作者" 容器id 目标镜像名:[TAG]
    

1、实战测试commit tomcat镜像

(1)启动一个默认的tomcat

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

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

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

docker images
docker run -it -p 8080:8080 tomcat
  • 这是一个前台程序

  • 将webapps.dist里面所有的文件拷贝到webapps里面
  • 提交commit镜像
docker commit -a="paidaxing" -m="add webapps app" 当前容器的id tomcat02:1.0

  • 发现新的版本,比之前的大了一些,因为里面记录了我们的改动

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

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



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



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

posted @ 2022-05-16 15:47  一乐乐  阅读(132)  评论(0编辑  收藏  举报