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

简介: 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


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

目录
相关文章
|
9月前
|
JavaScript Docker 容器
使用Docker多阶段构建优化镜像大小
使用Docker多阶段构建优化镜像大小
556 100
|
9月前
|
缓存 安全 Linux
优化Docker镜像大小的多阶段构建实践
优化Docker镜像大小的多阶段构建实践
547 99
|
9月前
|
缓存 Docker 容器
优化Docker镜像大小的五个实用技巧
优化Docker镜像大小的五个实用技巧
847 98
|
8月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
884 6
|
9月前
|
Java Docker 容器
使用Docker多阶段构建优化镜像大小
使用Docker多阶段构建优化镜像大小
374 8
|
存储 运维 Linux
2.docker架构,原理,安装及简单应用
docker的架构 先来看docker官网给出的docker架构图:
761 1
2.docker架构,原理,安装及简单应用
|
Ubuntu Linux 测试技术
Docker系列(1)--Docker原理及安装
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的。
274 0
Docker系列(1)--Docker原理及安装
|
Ubuntu Linux 测试技术
Docker系列(1)--Docker原理及安装| 更文挑战
Docker系列(1)--Docker原理及安装| 更文挑战
309 0
|
Kubernetes Cloud Native 数据可视化
【云原生 | Docker篇】轻松学会原理|架构|安装|加速(一)(下)
【云原生 | Docker篇】轻松学会原理|架构|安装|加速(一)(下)
315 0
【云原生 | Docker篇】轻松学会原理|架构|安装|加速(一)(下)
|
存储 Kubernetes Cloud Native
【云原生 | Docker篇】轻松学会原理|架构|安装|加速(一)(上)
【云原生 | Docker篇】轻松学会原理|架构|安装|加速(一)(上)
244 0
【云原生 | Docker篇】轻松学会原理|架构|安装|加速(一)(上)

热门文章

最新文章