Docker镜像超详细介绍
本文我们详细给大家来介绍下Docker中的镜像.1. 镜像是什么? 首先我们来看看镜像到底是什么?虽然前面有介绍过镜像和容器,但也不是特别的深入。镜像是一种轻量级、可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需的所有内容,包括代码、运行时、库、环境变量和配置文件。1.1 UnionFS UnionFS(联合文件系统): Union文...
本文我们详细给大家来介绍下Docker中的镜像
.
1. 镜像是什么?
首先我们来看看镜像到底是什么?虽然前面有介绍过镜像
和容器
,但也不是特别的深入。
镜像是一种轻量级、可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需的所有内容,包括代码、运行时、库、环境变量和配置文件。
1.1 UnionFS
UnionFS
(联合文件系统): Union文件系统(UnionFS)是一种分层
、轻量级
并且高性能
的文件系统
,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem)。Union 文件系统是 Docker 镜像的基础。镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
特性
:一次同时加载多个文件系统,但从外面看起来,只能看到一个文件系统,联合加载会把各层文件系统叠加起来,这样最终的文件系统会包含所有底层的文件和目录
1.2 镜像加载原理
Docker镜像加载原理:
docker的镜像实际上由一层一层的文件系统组成,这种层级的文件系统UnionFS。
bootfs(boot file system)主要包含bootloader和kernel, bootloader主要是引导加载kernel, Linux刚启动时会加载bootfs文件系统,在Docker镜像的最底层是bootfs。这一层与我们典型的Linux/Unix系统是一样的,包含boot加载器和内核。当boot加载完成之后整个内核就都在内存中了,此时内存的使用权已由bootfs转交给内核,此时系统也会卸载bootfs。
rootfs (root file system) ,在bootfs之上。包含的就是典型 Linux 系统中的 /dev, /proc, /bin, /etc 等标准目录和文件。rootfs就是各种不同的操作系统发行版,比如Ubuntu,Centos等等。
1.3 分层的镜像
其实我们前面在 pull 文件的时候比如 tomcat,在pull界面我们就可以看到下载的文件是一层层的。
1.4 分层结构的特点
其实我们也会考虑docker为什么会才用这种分层的结果,它有什么好处呢?最大的一个好处就是共享资源
比如:有多个镜像都从相同的 base 镜像构建而来,那么宿主机只需在磁盘上保存一份base镜像,同时内存中也只需加载一份 base 镜像,就可以为所有容器服务了。而且镜像的每一层都可以被共享
。
2. 镜像的特点
大家需要注意,docker镜像都是只读的,当容器启动时,一个新的可写层被加载到镜像的顶部,这一层通常被称为容器层
,容器层
之下的都叫镜像层
。
3. 镜像的操作
我们现在已经掌握了从docker hub
上获取相关镜像
,然后运行容器,并作出我们自己的处理,但有时候我们需要将我们自己的容器制作为对应的镜像,以便后面继续使用,这时我们就需要用到docker commit ...
命令了,这节我们就通过案例来介绍下 docker commit ...
命令的使用
docker commit -m="要提交的描述信息" -a="作者" 容器ID 要创建的目标镜像名:[标签名]
操作案例
我们通过tomcat
镜像来创建容器后操作处理,然后将容器制作为新的镜像然后我们通过新的镜像来制作容器来演示这个效果,有点绕,我们直接通过案例来说。
3.1 下载tomcat镜像
docker pull tomcat
创建tomcat
容器并运行
docker run -it -p 8888:8080 tomcat
参数说明
参数 | 说明 |
---|---|
-p | 主机端口:docker容器端口 |
-P | 随机分配端口 |
-i | 交互 |
-t | 终端 |
访问服务
3.2 删除doc
这时我们可以在tomcat中部署一个简单的服务,如下:
docker exec -it dae1df9c2b7c /bin/bash
删除doc服务
再访问
3.3 创建信息的镜像
接下来我们就可以把正在运行的容器制作为一个新的镜像了,
docker commit -a="bobo" -m="delete tomcat docs file" dae1df9c2b7c bobo/tomcat:1.666
3.4 启动新的镜像
现在我们可以启动我们自己制作的镜像来访问了。
docker run -it -p 8899:8080 bobo/tomcat:1.666
最后我们在启动tomcat
服务的时候我们可以通过 守护式
会更好些,如下
好了~镜像相关的内容就介绍到此,欢迎大家关注点赞哦 O(∩_∩)O哈哈~
更多推荐
所有评论(0)