ToB企服应用市场:ToB评测及商务社交产业平台

标题: 【云原生】第六篇--Dockerfile精讲及新型容器镜像构建技术 [打印本页]

作者: 反转基因福娃    时间: 2022-6-25 09:02
标题: 【云原生】第六篇--Dockerfile精讲及新型容器镜像构建技术
Dockerfile精讲及新型容器镜像构建技术



一、容器与容器镜像之间的关系

说到Docker管理的容器不得不说容器镜像,主要因为容器镜像是容器模板,通过容器镜像我们才能快速创建容器。
如下图所示:

   Docker Daemon通过容器镜像创建容器。
  二、容器镜像分类


三、容器镜像获取的方法

主要有以下几种:
1、在DockerHub直接下载
2、把操作系统中文件系统打包为容器镜像
3、把正在运行的容器打包为容器镜像,即docker commit
4、通过Dockerfile实现容器镜像的自定义及生成
四、容器镜像获取方法演示

4.1 在DockerHub直接下载

  1. # docker pull centos:latest
复制代码
  1. # docker pull nginx:latest
复制代码
4.2 把操作系统中文件系统打包为容器镜像

4.2.1 安装一个最小化的操作系统


4.2.2 把操作系统中文件系统进行打包

  1. # tar --numeric-owner --exclude=/proc --exclude=/sys -cvf centos7u6.tar /
复制代码
4.2.3 把打包后文件加载至本地文件系统生成本地容器镜像

  1. # ls
  2. centos7u6.tar
复制代码
  1. # docker import centos7u6.tar centos7u6:v1
复制代码
  1. # docker images
  2. REPOSITORY   TAG       IMAGE ID       CREATED         SIZE
  3. centos7u6    v1        130cb005b2dc   7 seconds ago   1.09GB
复制代码
  1. # docker run -it centos7u6:v1 bash
  2. [root@50f24f688b4d /]# ip a s
  3. 1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
  4.     link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
  5.     inet 127.0.0.1/8 scope host lo
  6.        valid_lft forever preferred_lft forever
  7. 7: eth0@if8: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default
  8.     link/ether 02:42:ac:11:00:02 brd ff:ff:ff:ff:ff:ff link-netnsid 0
  9.     inet 172.17.0.2/16 brd 172.17.255.255 scope global eth0
  10.        valid_lft forever preferred_lft forever
复制代码
4.3 把正在运行的容器打包为容器镜像

4.3.1 运行一个容器

  1. # docker run -it centos7u6:v1 bash
复制代码
4.3.2 在容器中安装应用

  1. [root@064aace45718 /]# yum -y install httpd
复制代码
4.3.3 把正在运行的容器打包为容器镜像

  1. [root@064aace45718 /]# ctrl + p +q
复制代码
  1. # docker commit 064aace45718 centos7u6-httpd:v1
复制代码
  1. # docker images
  2. REPOSITORY        TAG       IMAGE ID       CREATED         SIZE
  3. centos7u6-httpd   v1        30ec9d728880   6 seconds ago   1.29GB
复制代码
  1. # docker run -it centos7u6-httpd:v1 bash
  2. [root@01a1373b4a3f /]# rpm -qa | grep httpd
  3. httpd-tools-2.4.6-97.el7.centos.4.x86_64
  4. httpd-2.4.6-97.el7.centos.4.x86_64
复制代码
4.4 通过Dockerfile实现容器镜像的自定义及生成

4.4.1 Dockerfile介绍

Dockerfile是一种能够被Docker程序解释的剧本。Dockerfile由一条一条的指令组成,并且有自己的书写格式和支持的命令。当我们需要在容器镜像中指定自己额外的需求时,只需在Dockerfile上添加或修改指令,然后通过docker build生成我们自定义的容器镜像(image)。

4.4.2 Dockerfile指令


指令描述FROM构建新镜像基于的基础镜像LABEL标签RUN构建镜像时运行的Shell命令COPY拷贝文件或目录到镜像中ADD解压压缩包并拷贝ENV设置环境变量USER为RUN、CMD和ENTRYPOINT执行命令指定运行用户EXPOSE声明容器运行的服务端口WORKDIR为RUN、CMD、ENTRYPOINT、COPY和ADD设置工作目录CMD运行容器时默认执行,如果有多个CMD指令,最后一个生效
通过man dockerfile可以查看到详细的说明,这里简单的翻译并列出常用的指令
1、FROM
FROM指令用于指定其后构建新镜像所使用的基础镜像。
FROM指令必是Dockerfile文件中的首条命令。
FROM指令指定的基础image可以是官方远程仓库中的,也可以位于本地仓库,优先本地仓库。
  1. 格式:FROM <image>:<tag>
  2. 例:FROM centos:latest
复制代码
2、RUN
RUN指令用于在构建镜像中执行命令,有以下两种格式:

  1. 格式:RUN <命令>
  2. 例:RUN echo 'kubemsb' > /var/www/html/index.html
复制代码

  1. 格式:RUN ["可执行文件", "参数1", "参数2"]
  2. 例:RUN ["/bin/bash", "-c", "echo kubemsb > /var/www/html/index.html"]
复制代码

注意: 按优化的角度来讲:当有多条要执行的命令,不要使用多条RUN,尽量使用&&符号与\符号连接成一行。因为多条RUN命令会让镜像建立多层(总之就是会变得臃肿了
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4