8.Docker镜像讲解

镜像是什么?

镜像是一种轻量级、可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,让包含运行某个软件所需要的所有内容,包含代码、运行时候的库,环境变量和配置文件。
所有的应用直接打包成docker镜像部署。
如何获得镜像:

  • 从远程仓库下载
  • 朋友拷贝给你
  • 自己制作一个镜像DockerFile
docker镜像加载原理

UnionFS(联合文件系统)
UnionFS(联合文件系统):UnionFS(联合文件系统)是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂在同一个虚拟文件系统下。Union文件系统是Docker镜像的基础。镜像可以通过分层来进行继承,基于基础镜像(没有父镜像)。
特性:一次同时加载多个文件系统,但从外面看起来,只能看起来,只能看到一个文件系统,联合加载会把各层文件系统叠加起来,这样最终的文件系统会包含所有的底层文件和目录。

docker镜像加载原理

bootfs主要包含bootloader(加载器)和kernel(内核),bootloader(加载器)主要引导kernel(内核,Linux刚启动时会加载bootfs文件系统,在Docker镜像最底层是bootfs,这一层与我们典型的Linux/Unix系统是一样,包含boot加载器和内核。当boot加载完成之后整个内核都在内存中了,此时使用权转交给内核,此时系统会卸载bootfs。
黑屏------加载(加载完之后卸载)------开机进入系统
rootfs,在bootfs之上,包含的就是典型Linux系统中的/dev,/proc,/bin,/etc等标准目录和文件。rootfs就是各种不同的系统发行版,比如Ubuntu,Centos等等

平时我们安装进入虚拟机的Centos都是好几G,为什么docker这里才200M?

对于一个精简的OS,rootfs可以很小,只需要包含基础的命令,工具和程序库就可以了,因为底层直接用Host的kernel,自己只需要提供rootfs就可以了。

分层理解

分层镜像
我们可以去下载一个镜像,注意要观察下载的日志输出,可以看到一层一层的在下载!

思考为什么docker镜像要采用这种分层的结构?
最大的好处,就是资源的共享!比如有多个镜像都从相同的Base镜像构造而来,那么宿主级只需要在磁盘上保留一份base镜像,这样
比如这里,我安装redis,一层层部署中,有个already exists,这是因为在基于一层层搭建过程中,共享资源的原因,发现有些配置是已经存在了,直接使用就行

查看镜像分层的方式可以通过docker image inspect


特带:
Docker镜像都是只读的,当容器启动的时候,一个新的可写层被加载到镜像的顶部!
这一层就是我们通常说的容器层,容器之下的都叫镜像层。
这也是为什么我们可以通过一个镜像去run很多容器

可写层------容器层
只读层------镜像层

如何提交自己的镜像
commit镜像

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

实战测试

#官方默认tomcat镜像的webapps下面没有文件
#我想自己创建一个webapps下面默认有文件的镜像,方便后面我或者后面人使用。

重新开一个终端

docker exec -it c2188940d51f /bin/bash

进入容器,官方的webapps里面每次默认启动都是没有东西的,每次都需要将webapps.dist的文件拷贝在webapps下面。很麻烦
这里递归复制

这里拷贝完成
exit退出当前容器

这个容器依然还在
访问这个页面

部署成功了的

正式来到提交我们编辑的镜像

docker commit -a="jojo" -m="add webapps's dir" c2188940d51f tomcataddwebappsdir:1.0
-a="jojo" 作者:jojo
-m="add webapps's dir" 你这个镜像的描述
tomcataddwebappsdir:1.0 名字和版本号(自定义)

docker images

红框框里面就是我们编辑的镜像,不过这个是提交到本地
如何发布,在后面dockerfile学习章节中学习

相关推荐
梁bk1 小时前
[Nginx]反向代理和负载均衡
运维·nginx·负载均衡
(:满天星:)7 小时前
第31篇:块设备与字符设备管理深度解析(基于OpenEuler 24.03)
linux·运维·服务器·网络·centos
小陶来咯7 小时前
【仿muduo库实现并发服务器】Acceptor模块
运维·服务器
cui_hao_nan7 小时前
Docker后端部署
运维·docker·容器
ZZH1120KQ8 小时前
Linux系统安全及应用
linux·运维·系统安全
大苏打seven8 小时前
Docker学习笔记:Docker网络
笔记·学习·docker
小扎仙森8 小时前
关于服务器宝塔转移wordperss子比主题问题
运维·服务器
小小小糖果人8 小时前
Linux云计算基础篇(5)
linux·运维·服务器
我不是哆啦A梦8 小时前
破解风电运维“百模大战”困局,机械版ChatGPT诞生?
运维·人工智能·python·算法·chatgpt
小张是铁粉9 小时前
docker在Linux的安装遇到的问题
linux·docker·容器