Docker 镜像

镜像是什么

镜像是一种轻量级,可执行的独立包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需的所有内容,包括代码、运行时的库、环境变量、配置文件。
所有的应用,直接打包Docker镜像,就可以直接跑起来

镜像获取方式

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

Docker 镜像加载原理

UnionFS(联合文件系统)
下载时一层层的就是这个,类似Git版本控制

Union文件系统(UnionFS)是一种分层轻量级并且高性能的文件系统,它支持堵i文件系统的修改作为作为一次提交来一层层的叠加,同事可以将不同目录挂载到同一个虚拟文件系统(unite serveral directories into a single virtual filesystem)Union文件系统是Docker镜像(没有父镜像),可以制作各种具体的应用镜像。
特性:一次同事加载多个文件系统,但从外面看起来,只能看到一个文件系统,联合加载会把各层的文件系统叠加起来,这样最终的文件系统会包含所有底层的文件和目录

Docker镜像加载原理
Docker镜像时机上由一层层的文件系统组成,这种层级的文件系统是UnionFS

bootfs(boot file system)主要包含bootloader和kernel,bootloader主要是引导加载kernel,Linux刚启动时会加载bootfs文件系统,在Docker镜像的最底层是bootfs,这一层于我们典型的Linux/Unix系统是一样的,包含boot加载器和内核。当boot加载完成之后,整个内核就都在内存中了,此时内存的使用权已由bootfs转交给内核,此时系统也会卸载bootfs

rootfs(foot file system),在bootfs之上,包含的就是典型Linux系统中的/dev,/proc,/bin,/etc 等标准目录和文件
rootfs就是各种不同操作系统发行版,比如Ubuntu,centos等

对于一些比较精简的os,rootfs可以很小,只需要包含最基本的命令(cd,ls,mk…等,连ll,vim都没有)和工具、程序库积极可以了,因为底层直接用主机(host)的kernel,自己只需要提供rootfs就可以了,由此可见对于不同的Linux发行版,bootfs基本是一致的,rootfs会有差别,由此不同的发行版可以公用bootfs

分层理解

分层的理解

所有的Docker镜像都起始于一个基础镜像层,当进行修改或增加新的内容时,就会在当前镜像层之上,创建新的镜像层。
假如基于Ubuntu Linux 16.04 创建一个新的镜像,这就是新镜像的第一层;如果在该镜像中国呢添加Python包,就会在基础镜像层之上创建第二个镜像层,如果继续添加一个安全补丁,则会创建第三个镜像层。

docker下载镜像并启动_docker

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

如何提交一个自己的镜像

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

当你想要保存当前容器的状态,就可以通过commit来提交,获得一个镜像,类似与VM的快照。