Docker系列(镜像原理)03

简介: Docker系列(镜像原理)03

前言

镜像就是图中的集装箱,仓库就是超级码头,容器就是我们运行程序的地方。

从联合文件系统说起

Union文件系统(UnionFS )是一种分层、轻量级并且高性能的文件系统。它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下。Docker的镜像实际上正是由这一层一层的文件系统组成,这种多层级的文件系统称为联合文件系统(UnionFS)。

特性︰一次可以同时加载多个文件系统,但从外面看起来,只能看到一个文件系统,联合加载会把各层文件系统叠加起来,这样最终的文件系统会包含所有底层的文件和目录。

根文件系统

bootfs主要包含 bootloader 和 kernel,其中 bootloader 主要用来加载和引导 kernel,Linux启动时会加载bootfs文件系统,而Docker镜像的最底层就是bootfs。当bootloader 将kernel完全载入内存后,bootfs会把内存的使用权转交给内核,并卸载bootfs。

根文件系统(rootfs ),它在bootfs之上。比如:Linux系统中“/”根目录下的的/dev, /proc, /bin, /etc等标准目录和文件。rootfs就是各种不同的操作系统发行版,比如Ubuntu , Centos等等。

一、什么是镜像

镜像是一个只读的文件模板,打包了应用程序和应用程序依赖的文件系统以及启动容器的配置文件,是启动容器的基础。镜像打包的内容就是容器运行的系统环境——rootfs(根文件系统)。

上图是镜像的存储格式,从下往上一层层的好像集装箱罗列在一起,这就是镜像最直观的存储方式。最下面是操作系统的引导,上面是linux操作系统,再上面是一些相关的软件,如tomcat、Apache等,再往上是应用代码。

注意docker镜像系统的每一层都是只读的。每加载完一层,这一层对应的目录以及文件都会被放入同一个文件系统,上一层同名的目录以及文件会隐藏调下面的同名目录及文件,最终对外来看就是只有一个文件系统。

二、Docker镜像原理

2.1 分层构建

Docker镜像采用分层的方式构建,每个镜像都由一组镜像组合而成。每一层镜像层都可以被需要的镜像所引用,实现了镜像之间镜像层的共享。这使得在上传和下载镜像的过程中有效的减少了镜像传输的大小,在传输过程当中,本地或者注册中心只需要保存一份底层的基础镜像即可,真正被保存和下载的是用户构建的镜像层。构建过程中的镜像层会被缓存下来,后续如果是统一镜像层,会直接使用缓存加速构建过程。

2.2 写时复制

底层镜像在多个容器之间共享,每个容器在启动时不需要复制一份镜像文件,而是将所有需要的镜像层以只读的方式挂载到一个挂载点,在只读层上添加一层读写层。在容器运行过程中,产生的新文件或者被修改的文件会从底层复制到读写层进行修改,原来的文件会被隐藏。

2.3 联合挂载

Docker采用联合挂载技术(本质上就是联合文件系统,UnionFS),在同一个挂载点挂载多个文件系统,对外表现一个文件系统。

2.4 内容寻址

根据镜像层的内容计算校验和,根据校验和生成一个哈希值,并使用该值作为镜像层的ID。通过这个ID就能找个对应的镜像层。因为是基于内容的哈希值来索引镜像层,如果哈希值相同,表示内容相同,对于引用统一哈希值的镜像层,都可以用同一份镜像层。内容寻址提高了镜像的安全性,比如在:pull 、push 和 save、load操作后会检查数据的完整性。


推荐一个零声学院免费教程,个人觉得老师讲得不错,分享给大家:[Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK等技术内容,点击立即学习:

相关文章
|
11天前
|
Docker 容器
docker从指定repo拉取镜像
docker从指定repo拉取镜像
|
1天前
|
测试技术 持续交付 Docker
Docker in Docker原理与实战
Docker in Docker原理与实战
4 0
|
2天前
|
存储 安全 持续交付
【Docker 专栏】Docker 镜像的版本控制与管理
【5月更文挑战第9天】本文探讨了Docker镜像版本控制与管理的重要性,包括可重复性、回滚能力、协作开发和持续集成。常用方法有标签、构建参数和版本控制系统。管理策略涉及定期清理、分层管理和镜像仓库。语义化标签、环境变量和配置文件在版本控制中有应用。版本系统与Docker结合能跟踪历史和促进协作。注意点包括优化镜像大小、确保安全性和兼容性。案例分析和未来趋势展示了持续发展的镜像管理技术,为Docker应用的稳定与进步保驾护航。
【Docker 专栏】Docker 镜像的版本控制与管理
|
2天前
|
运维 安全 Docker
【Docker 专栏】Docker 镜像安全扫描与漏洞修复
【5月更文挑战第9天】Docker技术在软件开发和部署中带来便利,但其镜像安全问题不容忽视。本文探讨了Docker镜像安全扫描与漏洞修复,强调了镜像安全对应用和系统的重要性。文中介绍了静态和动态扫描方法,列举了软件漏洞、配置漏洞和恶意软件等常见安全问题,并提到了Clair和Trivy等扫描工具。修复策略包括更新软件、调整配置和重建镜像。此外,加强安全意识、规范镜像制作流程和定期扫描是管理建议。未来,将持续面对新的安全挑战,需持续研究和完善安全技术。
【Docker 专栏】Docker 镜像安全扫描与漏洞修复
|
3天前
|
Java Linux 数据安全/隐私保护
Docker自定义JDK镜像并拉取至阿里云镜像仓库全攻略
Docker自定义JDK镜像并拉取至阿里云镜像仓库全攻略
|
3天前
|
存储 弹性计算 运维
Docker数据集与自定义镜像:构建高效容器的关键要素
Docker数据集与自定义镜像:构建高效容器的关键要素
|
3天前
|
存储 缓存 运维
【Docker 专栏】Docker 镜像的分层存储与缓存机制
【5月更文挑战第8天】Docker 镜像采用分层存储,减少空间占用并提升构建效率。每个镜像由多个层组成,共享基础层(如 Ubuntu)和应用层。缓存机制加速构建和运行,通过检查已有层来避免重复操作。有效管理缓存,如清理无用缓存和控制大小,可优化性能。分层和缓存带来资源高效利用、快速构建和灵活管理,但也面临缓存失效和层管理挑战。理解这一机制对开发者和运维至关重要。
【Docker 专栏】Docker 镜像的分层存储与缓存机制
|
3天前
|
数据库 Docker 容器
【Docker 专栏】使用 Dockerfile 自动化构建 Docker 镜像
【5月更文挑战第8天】Dockerfile是构建Docker镜像的关键,它包含一系列指令,用于描述应用运行环境及所需软件包。通过自动化构建,能提高效率、保证可重复性并提升灵活性。确定基础镜像、安装依赖、设置环境后,执行Dockerfile生成镜像,用于应用程序部署。虽然需要熟悉Docker技术和应用细节,但其带来的益处使其成为现代软件开发和部署的重要工具。
【Docker 专栏】使用 Dockerfile 自动化构建 Docker 镜像
|
4天前
|
缓存 安全 数据安全/隐私保护
【Docker专栏】深入理解Docker镜像的构建与推送
【5月更文挑战第7天】本文介绍了Docker镜像的核心作用及基础概念,包括镜像作为容器模板的特性。文章详细阐述了Dockerfile的编写,例如设置基础镜像、工作目录、安装依赖及定义启动命令。通过`docker build`命令构建镜像,并提示了优化构建过程的技巧。此外,还讲解了如何将镜像推送到远程仓库,包括选择仓库、认证、标签和推送镜像的步骤,以及镜像安全性的考虑,如扫描漏洞和遵循最小权限原则。本文旨在帮助读者掌握Docker镜像的构建与推送,以高效管理容器化应用。
【Docker专栏】深入理解Docker镜像的构建与推送
|
5天前
|
运维 Linux 数据安全/隐私保护
Docker详解(九)——Docker镜像发布
Docker详解(九)——Docker镜像发布
28 2