12 - Dockerfile指令详解(Docker系列)

本文章来自【知识林】

在使用Dockerfile一构建Docker镜像之前需要先搞清楚Dockerfile中都有哪些常用的指令,这样在使用起来才能得心应手。

这篇文章主要列举出Dockerfile中比较常用的指令及其用法和说明,需要注意的是这些指令都是全部大写。

FROM

  • 说明:指定该镜像的基础镜像
  • 格式如:FROM <image>FROM <image>:<tag>
  • 示例:FROM centos:7
  • 注意:FROM一般出现在文件头,且每个镜像都需要有一个FROM来指定基础镜像。

MAINTAINER

  • 说明:指定作者信息
  • 格式如:MAINTAINER <name>
  • 示例:MAINTAINER 知识林 "393156105@qq.com"

RUN

  • 说明:在构建镜像时执行脚本
  • 格式如:RUN <command>RUN ["exec", "par1", "par2"]
  • 示例:RUN ls -l(以详细信息方式列表当前目录下的文件,跟在shell终端运行一样)

CMD

  • 说明:在运行容器时执行脚本
  • 格式如:CMD <command> <par1> <par2> ...CMD ["exec", "par1", "par2"]
  • 示例:CMD ["ls", "-l"]
  • 注意:一个Dockerfile中只有一条CMD,如果有多条只执行最后一条;在运行容器时如果用户指定了运行命令则Dockerfile中的CMD将被覆盖。

ENTRYPOINT

  • 说明:在运行容器时执行脚本
  • 格式如:ENTRYPOINT ["exec", "par1", "par2"]ENTRYPOINT command par1 par2
  • 示例:ENTRYPOINT ["catalina.sh", "run"]
  • 注意:一个Dockerfile中只有一条ENTRYPOINT,如果有多条只执行最后一条;不可以被容器运行时的命令所覆盖。

EXPOSE

  • 说明:让Docker暴露容器的端口号,供其他容器使用,在宿主机以外的网络中是无法使用的
  • 格式如:EXPOSE <port> ...
  • 示例:EXPOSE 8080
  • 注意:
    • 在Docker中有两种暴露端口的概念,一种叫EXPOSE隐式暴露,只供Docker服务内部使用;另一种叫PUBLISH显式暴露,供外部网络使用,PUBLISH只是一个概念在Dockerfile中没有这个指令。
    • EXPOSE 只在Dockerfile中出现,所暴露的端口只是被其他容器使用
    • PUBLISH 没有该指令而是通过docker run命令的参数-p-P或在docker-compose中的ports来体现
    • -P:大写是属于自动映射,将Dockerfile中EXPOSE所暴露的所有端口分别映射到宿主机的随机端口,每次启动或重启容器时端口都可能有所不同
    • -p:小写是属于固定映射,格式如:-p 宿主端口:容器端口,宿主端口和容器端口可以是纯数字也可以是一个范围,如:-p 8060-8080:8060-8080,意为将宿主机的8060(含)到8080(含)的端口映射到容器的8060(含)到8080(含)端口,需要注意的是在使用范围时,宿主端口个数应该与容器端口个数匹配;但上面这个例子可以写成:-p 7060-7080:8060-8080,这样宿主的端口就在7060-7080范围内

ENV

  • 说明:指定环境变量,在Dockerfile文件中的后续代码中使用,在容器运行时也可以使用
  • 格式如:ENV <key> <value>
  • 示例:ENV tomcat_home /web/tomcat/

ADD

  • 说明:添加文件(夹)到容器
  • 格式如:ADD <src> <dest>
  • 示例:ADD web.jar /web.jar
  • 注意:复制指定的<src>到容器中的<dest><src>可以是Dockerfile所在目录的一个相对路径,也可以是一个URL,也可以是一个tar文件(tar文件将自动解压成文件目录)

COPY

  • 说明:添加文件(夹)到容器
  • 格式如:COPY <src> <dest>
  • 示例:COPY web.jar /web.jar
  • 注意:与ADD功能相似,只是不能指定URL,使用本地文件(夹)为源文件时,推荐使用COPY

VOLUME

  • 说明:创建挂载点
  • 格式如:VOLUME [path]
  • 示例:VOLUME ["/datas"]
  • 注意:
    • VOLUME在原理和概念上与EXPOSE差不多,都是属于供容器与容器间使用
    • 通过VOLUME挂载的卷可以供其他容器使用
    • 举例说明:
      • 创建一个Dockerfile来构建一个镜像,内容如下:

          FROM centos
          VOLUME ["/web/images", "/web/files"]
        
      • 构建镜像

          docker build -t "zsl131/test01" .
        
      • 启动容器

          docker run -d --name test-root
        
      • 可以使用命令:docker inspect test-root来查看容器详细信息,在Mounts部份可以看到两个挂载点:/web/images/web/files

      • 启动另一个容器来共用这两个挂载卷

          docker run -it --name test-1 --volumes-from test-root centos
        

        注意:使用--volumes-from来指定挂载点,这时容器test-roottest-1里面都分别有挂载卷/web/images/web/files,可以启动任意多个容器使用--volumes-from来共用这些挂载卷,这些容器可以来自不同的镜像。当任何一个容器中的挂载卷中的文件发生变化时其他容器挂载卷中的内容也随之改变。

        容器test-root即使已经停止也可以在启动其他容器时使用--volumes-from test-root来挂载这些卷,只要test-root不被删除,不过如果test-root真被删除还可以使用--volumes-from test-1,因为容器test-1中还存在我们所需要的挂载卷,换句话说这些挂载卷永远存在直到所有使用这些挂载卷的容器都被删除。

      • VOLUMEdocker run参数-v是有区别的。docker run -v /host/web/images:/web/images -v /host/web/files:/web/files:rw是将容器内的/web/images挂载到宿主机的/host/web/images目录上;将容器内的/web/files挂载到宿主机的/host/web/files目录上,rw表示可读写。

WORKDIR

  • 说明:设置工作目录
  • 格式如:WORKDIR /path
  • 示例:WORKDIR /web
  • 注意:可以使用绝对路径,也可以使用相对路径,设置之后的所有操作都将在这个目录下完成

特别注意

在上面的描述中可以看到有两组指令在功能上都差不多,但也是有区别的:

  • RUNCMDENTRYPOINT执行脚本的指令

    • 三个指令都是执行脚本
    • RUN是在创建镜像是执行,即使用docker build命令时执行,在一个Dockerfile里面可以有多个RUN
    • CMDENTRYPOINT是在运行容器时执行,即使用docker run命令时执行,这两个指令在Dockerfile中都只有最行一条被执行
    • CMD在使用docker run时可以加参数将Dockerfile中的CMD覆盖
    • ENTRYPOINT在Dockerfile中出现后就一定会在docker run时被执行,不必担心会被其他参数所覆盖。
  • ADDCOPY拷贝文件(夹)到容器

    • ADD拷贝文件(夹)时可以指定本地文件、远程URL地址,如果拷贝的是tar文件时将会被自动解压成文件夹
    • COPY拷贝文件(夹)时不可以指定远程URL地址,拷贝tar文件也不会被自动解压成文件夹,在拷贝本地文件时建议使用COPY

本文章来自【知识林】

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 195,980评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,422评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,130评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,553评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,408评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,326评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,720评论 3 386
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,373评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,678评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,722评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,486评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,335评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,738评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,283评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,692评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,893评论 2 335

推荐阅读更多精彩内容

  • 转载自 http://blog.opskumu.com/docker.html 一、Docker 简介 Docke...
    极客圈阅读 10,458评论 0 120
  • 五、Docker 端口映射 无论如何,这些 ip 是基于本地系统的并且容器的端口非本地主机是访问不到的。此外,除了...
    R_X阅读 1,720评论 0 7
  • 一、Docker创建镜像的方式有两种: 一种通过commit的方式:把做了一系列操作的容器关闭,然后利用docke...
    jie0112阅读 3,816评论 0 3
  • Docker — 云时代的程序分发方式 要说最近一年云计算业界有什么大事件?Google Compute Engi...
    ahohoho阅读 15,490评论 15 147
  • 格局太小,自己太low,永远把自己框在自己的认知里,能有什么未来呢? 晚上和几个亲戚一起聊天,聊到其中一位的孩子时...
    biliali阅读 235评论 0 0