《Docker从入门到跑路》之Dockerfile基本操作
一、简介
Dockerfile是一个文本文件,里面包含一条条指令,每一条指令就是一层镜像。
一般情况下,Dockerfile分为4个部分:
- 基础镜像
- 维护者信息
- 镜像操作指令
- 容器启动时执行命令
例如:
FROM docker.io/centos
LABEL "auth"="joker" \
"mail"="unclejoker520@163.com"
ENV TIME_ZOME Asia/Shanghai
RUN yum install -y gcc gcc-c++ make openssl-devel prce-devel
ADD nginx-1.14.2.tar.gz /opt/
RUN cd /opt/nginx-1.14.2 && \
./configure --prefix=/usr/local/nginx && \
make -j 4 && \
make install
RUN rm -rf /opt/nginx* && \
yum clean all && \
echo "${TIME_ZOME}" > /etc/timezone && \
ln -sf /usr/share/zoneinfo/${TIME_ZOME} /etc/localtime
COPY nginx.conf /usr/local/nginx/conf/
WORKDIR /usr/local/nginx/
EXPOSE 80
CMD ["./sbin/nginx","-g","daemon off;"]
其中FROM指令必须是开篇第一个非注释行,是必须存在的一个指令,后面所有的操作都是基于这个镜像的。后面的指令就是一些操作指令,指令的详情在后面介绍。最后是CMD指定,这个指令表示在容器运行是需要执行的命令。
二、工作逻辑
1、在一个自定义的目录下有Dockerfile文件;
- 命名首字母必须是大写;
- 引用的文件必须在当前的目录及其一下目录;
- 如果有些文件不需要被打包,可以将这些文件当前目录下隐藏文件(.dockeringore)中;
2、在当前目录下执行docker build来进行打包成镜像,Dockerfile中的命令必须是docker支持的命令;
3、基于刚才打包的镜像启动容器;
通过Dockerfile制作成镜像并启动容器的过程如下:
其中上面提到的CMD指令还有后面介绍的ENTRYPOINT指令都是在docker run的时候执行,其他指令在docker build的时候执行。
三、指令介绍
3.1 FROM
重要且必须是开篇第一个非注释行,用于为映像文件构建过程指定基础镜像,后续的指令运行是在此基础上运行。在实践中,基础镜像可以是任何可用镜像文件,默认情况下,docker build 会在docker主机上查找指定的镜像文件,在其不存在时,则会从docker HUB上拉取镜像,如果找不到镜像,则会报错。
语法如下:
FROM <repository>[:<tag>] 或 FROM <repository>@<digest>
- <repository>:指定作为base image的名称
- <tag>:base image的标签,为可省略项,省略时默认为latest
3.2 MAINTANIER
用于指定Dockerfile制作者本人的信息,目前已经废弃了。
语法如下:
MAINTANIER <AUTHOR'S detail>
3.3 LABEL
指定Dockerfile的标签信息,我们可以将MAINTANIER的作者信息写在LABEL标签里。
语法如下:
LABEL <key>=<value>
3.4 COPY
从docker主机复制文件到镜像中。
语法如下:
COPY <SRC>...<DEST> 或者
COPY ["<SRC>",..."<DEST>"]
其中:
- SRC :源文件或目录;
- DEST:目标路径,建议用绝对路径;
注意:
- 路径中有空白文件,通常使用第二种;
- SRC目录,其内部文件和子目录会被递归复制,但是,但是SRC不会被复制;
- 复制多个SRC,则DEST必须是一个,切必须以/结尾;
- 如果DEST不存在,则会自动创建;
3.5 ADD
ADD命令和COPY命令有相似之处,都是像镜像中添加内容。
语法如下:
ADD <src>...<dest> 或者
ADD ["<src>",...,"<dest>"]
操作准则如下:
- 如果SRC为URL,且DEST不以/结尾,则SRC指定的文件将被下载并直接创建为DEST;如果DEST以/结尾,则文件名URL指定的文件将被直接下载并保存为/;
- 如果SRC是一个本地系统上的压缩格式的tar文件,它将直接展开为一个目录,其行为类似于“tar -x”命令;然而,通过URL获取到的tar文件将不会自动展开;
- 如果SRC有多个,或其间接或直接使用的通配符,则DEST必须是一个以/结尾的目录路径;如果dest不以/结尾,则其被视作一个普通文件,SRC的内容将被直接写入到dest;
3.6 WORKDIR
指定工作目录,每一次只影响当前目录到后的目录。
语法如下:
WORKDIR PATH
3.7 VOLUME
用于在image中创建一个挂载点目录,以挂载docker主机上的卷或者其它容器上的卷。
语法如下:
VOLUME <mountpoint> 或者
VOLUME ["<mountpoint>"]
注意:如果挂载点目录路径下存在文件,docker run 命令会在挂载完成后将此前得所有文件复制到新挂载的卷中。
3.8 EXPOSE
用于为容器打开指定要监听的端口以实现与外部通信,在docker run的时候,如果没有指定-P参数,是不会暴露在docker 主机上的。
语法如下:
EXPOSE <port>[/<portocol>] <port>[/<portocol>]
其中:用于指定传输层协议,可以是tcp或udp二者之一,默认是TCP。
EXPOSE指令可以一次指定多个端口,例如:
EXPOSE 11222/udp 11222/tcp
3.9 ENV
用于为镜像定义所需环境变量,并可被dockerfile文件中位于其后的其他指定所调用。如果在docker run的时候,在Dockerfile中指定的变量名如果没有被替换,在容器启动后通过执行printenv指令依然可以看到我们在Dockerfile中定义的变量。
语法如下:
ENV <key> <value> 或者
ENV <key>=<value>
其中:
- 第一种格式中,之后的所有内容均被视作value,因此,一次只能设置一个变量;
- 第二种格式可以设置多个变量,每个变量为一个=的键值对,如果中包含空格,可以用\进行转义,也可以用个对加""进行标识;另外,反斜杠也可用于续行;
- 定义多个变量时,建议使用第二种方式,以便在同一层中完成所有功能;
调用方式为:
$variable_nam 或者
${variable_nam}
如果要指定默认参数可以用下面格式:
${variable_name:-word} # 变量为空,就用word,变量有值,就用本身的值
${variable_name:+word} # 变量有值就现实word,没有值就不显示
3.10 RUN
用于指定docker build过程中运行的程序,其可以是任何可执行命令。
语法如下:
RUN <COMMAND> 或者
RUN ["executable","<param1>","<param2>"]
其中:
- 第一种格式中,通常是一个shell命令,且以“/bin/sh -c”来运行它,这意味着次进程在容器中的PID不为1,不能接受Unix信号,因此,当使用docker stop 命令停止容器时,此进程接受不到SIGTERM信号;
- 第二种语法格式中的参数是一个JSON格式的数组,其中为要运行的命令,后面的为传递给命令的选项或参数,然而,这种格式的指定不会以"/bin/sh -c"来发起,因此常见的shell操作如变量替换以及通配符(?,*等)将不会被替换,如果要运行的命令依赖于此shell特性的话,可以将其替换为下面的格式:
RUN ["/bin/sh","-c","<executable>","<param1>","<param2>"]
3.11 CMD
类似于RUN命令,CMD指令也可以运行命令或应用程序,不过二者的运行时间点不同:
- RUN指令运行于映像文件构建过程,CMD运行于docker run的时候;
- CMD指令的首要目的在于启动容器的时候运行程序,切她运行结束后,容器也将终止,不过CMD指令可以被docker run的命令选项所覆盖;
- 在Dockerfile中可以存多个CMD指令,但仅最后一个会生效;
语法如下:
CMD <command> 或者
CMD ["<executable>","<param1>","<param2>"] 或者
CMD ["<param1>","<param2>"]
其中:
- 前两种语法格式的意义同与RUN;
- 第三种则用于ENTRYPOINT指令提供默认参数;
3.12 ENTRYPOINT
类似CMD指令功能,用于容器指定默认运行程序,从而使得容器像是一个单独的可执行程序。
与CMD不同的是,由ENTRYPOINT启动程序不会被docker run命令指定的参数覆盖,而且,这些命令参数会被当做参数传递给ENTRYPOINT指定的程序。不过,docker run 命令的 --entrypoint选项的参数可覆盖NETRYPOINT指定的程序。
语法如下:
ENTRYPOINT <command> 或者
ENTRYPOINT ["<executable>","<param1>","<param2>"]
其中:
- docker 命令传入的参数会覆盖CMD指令的内容且附加到ENTRYPOINT命令最后作为其参数使用;
- dockerfile文件中也可以存在多个ENTRYPOINT指令,但最后一个有效;
3.13 USER
用于指定运行image时的或运行dockerfile中任何RUN,CMD或者ENTRYPOINT指令指定的程序的用户名或UID。
语法如下:
USER daemon
当服务器不需要管理员权限时,可以使用该命令指定运行用户,并且可以在之前创建所需要的用户,例如:
RUN groupadd -r test && \
useradd -r -g test test
如果需要临时获取管理员权限,推荐使用gosu,而不推荐sudo。
3.14 HEALTHCHECK
健康检查,可以设置定时去检查应用是否正常。
语法如下:
HEALTHCHECK [OPTIONS] CMD command
--interval=DURATION (default=30s)
--timeout=DURATION (default=30s)
--start-period=DURATION (default=0s)
--retries=N (default=3)
返回值:0是成功,1是失败,2是预留值。
3.15 SHELL
指定SHELL环境,默认是/bin/sh -c
3.16 ARG
ARG在build的时候使用,语法如下:
ARG <name>[=,default value.]
比如:
ARG NGINX_TAG="1.14"'
docker build --build-arg NGINX_TAG="1.15"
3.17 ONBUILD
用于在dockerfile中定义一个触发器。
dockerfile用于build映像文件,此映像文件亦可作为base image被另一个dockerfile用作FRM指令参数,并以之构建新的映像,在后面的dockerfile中的FROM指令在build过程中被执行时,将会触发创建其baseimage的dockerfile文件中的ONBUILD指令定义的触发器。
语法如下:
ONBUILD <INSTRUCTION>
注意:
- 尽管任何指令都可以注册成触发器指令,但ONBUILD不能自我嵌套,其不会触发FROM和MAINTAINER指令;
- 使用包含ONBUILD指令的dockerfile构建镜像应该使用特殊的标签,例如ruby:2.0-onbuild;
- 在ONBUILD指令中使用ADD或COPY指令应该格外小心,因为新构建过程中的上下文在缺少指定的源文件时会失败;
《Docker从入门到跑路》之Dockerfile基本操作的更多相关文章
- 《Docker从入门到跑路》之镜像和容器的基本操作
一.获取镜像 官方提供了一个公共镜像仓库Docker Hub,默认是从这上面获取镜像的. 搜素镜像使用docker search 命令: # docker search --help Usage: d ...
- 《Docker从入门到跑路》之基本用法介绍
Docker是一种轻量级的虚拟化技术,它具备传统虚拟机无法比拟的优势,它更简易的安装和使用方式.更快的速度.服务集成和开源流程自动化. Docker的安装 安装Docker的基本要素:1.Docker ...
- 《Docker从入门到跑路》之简介
什么是Docker Docker,中文翻译是"码头工人".根据官方的定义,Docker是以Docker容器为资源分割和调度的基本单元,封装了整个软件运行的环境,为开发者和系统管理员 ...
- 《Docker从入门到跑路》之多阶段构建
多阶段构建就是在一个Dokcerfile中定义多个FROM,每个FROM都可以使用不同的基础镜像,并表示开始一个新的构建阶段,我们可以很方便的将一个阶段的文件复制到另外一个阶段中,在最终的阶段保存你需 ...
- 《Docker从入门到跑路》之存储卷介绍
默认情况下,容器会随着用户删除而消失,包括容器里面的数据.如果我们要对容器里面的数据进行长久保存,就不得不引用存储卷的概念. 在容器中管理数据持久化主要有两种方式:1.数据卷(data volumes ...
- 《Docker从入门到跑路》之网络模型介绍
Bridge模式 当我们安装完docker后,启动Docker daemon,就会在主机上看到一个docker0的网桥,默认在此主机上启动的容器都会连接到这个网桥上.虚拟网桥的工作方式和物理交换机的工 ...
- 反手来个K8S入门到跑路
layout: post title: 反手来个K8S入门到跑路 category: linux date: 2019-06-09 tags: linux k8s 反手来个K8S入门到跑路 前言 放假 ...
- Spring全家桶系列–[SpringBoot入门到跑路]
//本文作者:cuifuan Spring全家桶————[SpringBoot入门到跑路] 对于之前的Spring框架的使用,各种配置文件XML.properties一旦出错之后错误难寻,这也是为什么 ...
- TiDB入门(四):从入门到“跑路”
前言 前面三章基本把 TiDB 的环境弄好了,也做了一下简单测试,有兴趣的同学可以看一下: TiDB 入门(一):TiDB 简介 TiDB 入门(二):虚拟机搭建 TiDB-Ansible 部署方案 ...
随机推荐
- mysql截取函数常用方法 即mysql 字符串 截取-- - 最后带上java字符串截取规则比较
常用的mysql截取函数有:left(), right(), substring(), substring_index() 下面来一一说明一下: 1.左截取left(str, length) 说明:l ...
- ftl中几个特殊的用法
@ 注意${}为变量的渲染显示,即先计算后打印出来,而<>里面为定义等操作符的定义 ,而首尾2个<>中间部分一般为计算打印部分 @数据模型中如果不是以map数据来封装的,而是直 ...
- Jackson优化使用实例
Jackson优化使用实例 博客分类: Java综合 JSON的三种处理方式 Jackson提供了三种可选的JSON处理方法(一种方式及其两个变型): 流式 API:(也称为"增量分析 ...
- 选择IT行业的自我心得,希望能帮助到各位!(六)
在这个社会,想做大事的人很多,但是很多事情也挺难做的,为什么说复杂的事情简单做,简单的事情重复做,这样一个人才能获得更多的优越品质,为啥说改变,人还是挺难过的,都知道本性难移,想改挺难得.在这个社会千 ...
- docker 概览 (1)
Docker Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化.容器是完全使 ...
- ASE课程总结 by 冯晓云
开始的开始,采访往届ASE班的blog:http://www.cnblogs.com/legs/p/4894362.html 和北航软工M1检查:http://www.cnblogs.com/legs ...
- Gun N' Rose Team Review
一看到这个项目就被他的功能给吸引了.回忆起以前看到一个东西很新奇想去网上查询它是什么,但是又不知道应该怎样去描述它,于是在搜索引擎的输入框中键入.删除.键入.删除的可笑经历的时候,我就越发感觉到这个a ...
- Python - 翻译Talk Python To Me (和我聊Python) 播客
“和我聊Python”是一个美国的聊天播客,英文名Talk Python To Me,类似于喜马拉雅的音频课程节目,只不过这个主题是编程语言Python.该节目从2015年的节目到现在,已经超过256 ...
- 《并发编程的艺术》阅读笔记之Volatile
来源 在 JDK1.2 之前,Java的内存模型实现总是从主存(即共享内存)读取变量,是不需要进行特别的注意的.而在当前的 Java 内存模型下,线程可以把变量保存本地内存(比如机器的寄存器)中,而不 ...
- 几个可以提高工作效率的Python内置小工具
在这篇文章里,我们将会介绍4个Python解释器自身提供的小工具.这些小工具在笔者的日常工作中经常用到,减少了各种时间的浪费,然而,却很容易被大家忽略.每当有新来的同事看到我这么使用时,都忍不住感叹, ...