美文网首页
2019-04-23-docker基本知识(镜像)

2019-04-23-docker基本知识(镜像)

作者: 妞儿是只猫 | 来源:发表于2020-06-12 16:11 被阅读0次

    镜像是 Docker 容器的基石,容器是镜像的运行实例,有了镜像才能启动容器。

    本章内容安排如下:

    首先通过研究几个典型的镜像,分析镜像的内部结构。

    然后学习如何构建自己的镜像。

    最后介绍怎样管理和分发镜像。

    镜像的内部结构

    为什么我们要讨论镜像的内部结构?

    如果只是使用镜像,当然不需要了解,直接通过docker命令下载和运行就可以了。

    但如果我们想创建自己的镜像,或者想理解 Docker 为什么是轻量级的,就非常有必要学习这部分知识了。

    我们从一个最小的镜像开始吧。

    hello-world - 最小的镜像

    hello-world 是 Docker 官方提供的一个镜像,通常用来验证 Docker 是否安装成功。

    我们先通过docker pull从 Docker Hub 下载它。

    用docker images命令查看镜像的信息。

    hello-world 镜像竟然还不到 2KB!

    通过docker run运行。

    其实我们更关心 hello-world 镜像包含哪些内容。

    Dockerfile 是镜像的描述文件,定义了如何构建 Docker 镜像。Dockerfile 的语法简洁且可读性强,后面我们会专门讨论如何编写 Dockerfile。

    hello-world 的 Dockerfile 内容如下:

    只有短短三条指令。

    FROM scratch

    此镜像是从白手起家,从 0 开始构建。

    COPY hello /

    将文件“hello”复制到镜像的根目录。

    CMD ["/hello"]

    容器启动时,执行 /hello

    镜像 hello-world 中就只有一个可执行文件 “hello”,其功能就是打印出 “Hello from Docker ......” 等信息。

    /hello 就是文件系统的全部内容,连最基本的 /bin,/usr, /lib, /dev 都没有。

    hello-world 虽然是一个完整的镜像,但它并没有什么实际用途。通常来说,我们希望镜像能提供一个基本的操作系统环境,用户可以根据需要安装和配置软件。这样的镜像我们称作 base 镜像。

    我们下一节讨论 base 镜像

    base 镜像有两层含义:

    不依赖其他镜像,从 scratch 构建。

    其他镜像可以之为基础进行扩展。

    所以,能称作 base 镜像的通常都是各种 Linux 发行版的 Docker 镜像,比如 Ubuntu, Debian, CentOS 等。

    我们以 CentOS 为例考察 base 镜像包含哪些内容。

    下载镜像:

    docker pull centos

    查看镜像信息:

    镜像大小不到 200MB。

    等一下!

    一个 CentOS 才 200MB ?

    平时我们安装一个 CentOS 至少都有几个 GB,怎么可能才 200MB !

    相信这是几乎所有 Docker 初学者都会有的疑问,包括我自己。下面我们来解释这个问题。

    Linux 操作系统由内核空间和用户空间组成。如下图所示:

    rootfs

    内核空间是 kernel,Linux 刚启动时会加载 bootfs 文件系统,之后 bootfs 会被卸载掉。

    用户空间的文件系统是 rootfs,包含我们熟悉的 /dev, /proc, /bin 等目录。

    对于 base 镜像来说,底层直接用 Host 的 kernel,自己只需要提供 rootfs 就行了。

    而对于一个精简的 OS,rootfs 可以很小,只需要包括最基本的命令、工具和程序库就可以了。相比其他 Linux 发行版,CentOS 的 rootfs 已经算臃肿的了,alpine 还不到 10MB。

    我们平时安装的 CentOS 除了 rootfs 还会选装很多软件、服务、图形桌面等,需要好几个 GB 就不足为奇了。

    base 镜像提供的是最小安装的 Linux 发行版

    下面是 CentOS 镜像的 Dockerfile 的内容:

    第二行 ADD 指令添加到镜像的 tar 包就是 CentOS 7 的 rootfs。在制作镜像时,这个 tar 包会自动解压到 / 目录下,生成 /dev, /proc, /bin 等目录。

    注:可在 Docker Hub 的镜像描述页面中查看 Dockerfile 。

    支持运行多种 Linux OS

    不同 Linux 发行版的区别主要就是 rootfs。

    比如 Ubuntu 14.04 使用 upstart 管理服务,apt 管理软件包;而 CentOS 7 使用 systemd 和 yum。这些都是用户空间上的区别,Linux kernel 差别不大。

    所以 Docker 可以同时支持多种 Linux 镜像,模拟出多种操作系统环境。

    上图 Debian 和 BusyBox(一种嵌入式 Linux)上层提供各自的 rootfs,底层共用 Docker Host 的 kernel。

    这里需要说明的是:

    base 镜像只是在用户空间与发行版一致,kernel 版本与发行版是不同的。

    例如 CentOS 7 使用 3.x.x 的 kernel,如果 Docker Host 是 Ubuntu 16.04(比如我们的实验环境),那么在 CentOS 容器中使用的实际是是 Host 4.x.x 的 kernel。

    ① Host kernel 为 4.4.0-31

    ② 启动并进入 CentOS 容器

    ③ 验证容器是 CentOS 7

    ④ 容器的 kernel 版本与 Host 一致

    容器只能使用 Host 的 kernel,并且不能修改。

    所有容器都共用 host 的 kernel,在容器中没办法对 kernel 升级。如果容器对 kernel 版本有要求(比如应用只能在某个 kernel 版本下运行),则不建议用容器,这种场景虚拟机可能更合适。

    相关文章

      网友评论

          本文标题:2019-04-23-docker基本知识(镜像)

          本文链接:https://www.haomeiwen.com/subject/qftvgqtx.html