青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Benjamin

靜以修身,儉以養(yǎng)德,非澹薄無(wú)以明志,非寧?kù)o無(wú)以致遠(yuǎn)。
隨筆 - 398, 文章 - 0, 評(píng)論 - 196, 引用 - 0
數(shù)據(jù)加載中……

Dockerfile相關(guān)命令詳解

FROM
功能為指定基礎(chǔ)鏡像,并且必須是第一條指令。
如果不以任何鏡像為基礎(chǔ),那么寫(xiě)法為:FROM scratch。
同時(shí)意味著接下來(lái)所寫(xiě)的指令將作為鏡像的第一層開(kāi)始
語(yǔ)法:
FROM <image>
FROM <image>:<tag>
FROM <image>:<digest> 
三種寫(xiě)法,其中<tag>和<digest> 是可選項(xiàng),如果沒(méi)有選擇,那么默認(rèn)值為latest
 
RUN
功能為運(yùn)行指定的命令
RUN命令有兩種格式
1. RUN <command>
2. RUN ["executable", "param1", "param2"]
第一種后邊直接跟shell命令
在linux操作系統(tǒng)上默認(rèn) /bin/sh -c
在windows操作系統(tǒng)上默認(rèn) cmd /S /C
第二種是類(lèi)似于函數(shù)調(diào)用。
可將executable理解成為可執(zhí)行文件,后面就是兩個(gè)參數(shù)。
兩種寫(xiě)法比對(duì):
RUN /bin/bash -c 'source $HOME/.bashrc; echo $HOME
RUN ["/bin/bash", "-c", "echo hello"]
注意:多行命令不要寫(xiě)多個(gè)RUN,原因是Dockerfile中每一個(gè)指令都會(huì)建立一層.
 多少個(gè)RUN就構(gòu)建了多少層鏡像,會(huì)造成鏡像的臃腫、多層,不僅僅增加了構(gòu)件部署的時(shí)間,還容易出錯(cuò)。
RUN書(shū)寫(xiě)時(shí)的換行符是\
 
CMD
功能為容器啟動(dòng)時(shí)要運(yùn)行的命令
語(yǔ)法有三種寫(xiě)法
1. CMD ["executable","param1","param2"]
2. CMD ["param1","param2"]
3. CMD command param1 param2
第三種比較好理解了,就時(shí)shell這種執(zhí)行方式和寫(xiě)法
第一種和第二種其實(shí)都是可執(zhí)行文件加上參數(shù)的形式
舉例說(shuō)明兩種寫(xiě)法:
CMD [ "sh", "-c", "echo $HOME" 
CMD [ "echo", "$HOME" ]
補(bǔ)充細(xì)節(jié):這里邊包括參數(shù)的一定要用雙引號(hào),就是",不能是單引號(hào)。千萬(wàn)不能寫(xiě)成單引號(hào)。
原因是參數(shù)傳遞后,docker解析的是一個(gè)JSON array
 
RUN & CMD
不要把RUN和CMD搞混了。
RUN是構(gòu)件容器時(shí)就運(yùn)行的命令以及提交運(yùn)行結(jié)果
CMD是容器啟動(dòng)時(shí)執(zhí)行的命令,在構(gòu)件時(shí)并不運(yùn)行,構(gòu)件時(shí)緊緊指定了這個(gè)命令到底是個(gè)什么樣子
LABEL
功能是為鏡像指定標(biāo)簽
語(yǔ)法:
LABEL <key>=<value> <key>=<value> <key>=<value> ...
 一個(gè)Dockerfile種可以有多個(gè)LABEL,如下:
LABEL "com.example.vendor"="ACME Incorporated"
LABEL com.example.label-with-value="foo"
LABEL version="1.0"
LABEL description="This text illustrates \
that label-values can span multiple lines."
 但是并不建議這樣寫(xiě),最好就寫(xiě)成一行,如太長(zhǎng)需要換行的話則使用\符號(hào)
如下:
LABEL multi.label1="value1" \
multi.label2="value2" \
other="value3"
說(shuō)明:LABEL會(huì)繼承基礎(chǔ)鏡像種的LABEL,如遇到key相同,則值覆蓋
MAINTAINER
指定作者
語(yǔ)法:
MAINTAINER <name>
 
EXPOSE
功能為暴漏容器運(yùn)行時(shí)的監(jiān)聽(tīng)端口給外部
但是EXPOSE并不會(huì)使容器訪問(wèn)主機(jī)的端口
如果想使得容器與主機(jī)的端口有映射關(guān)系,必須在容器啟動(dòng)的時(shí)候加上 -P參數(shù)
ENV
功能為設(shè)置環(huán)境變量
語(yǔ)法有兩種
1. ENV <key> <value>
2. ENV <key>=<value> ...
兩者的區(qū)別就是第一種是一次設(shè)置一個(gè),第二種是一次設(shè)置多個(gè)
ADD
 一個(gè)復(fù)制命令,把文件復(fù)制到景象中。
如果把虛擬機(jī)與容器想象成兩臺(tái)linux服務(wù)器的話,那么這個(gè)命令就類(lèi)似于scp,只是scp需要加用戶(hù)名和密碼的權(quán)限驗(yàn)證,而ADD不用。
語(yǔ)法如下:
1. ADD <src>... <dest>
2. ADD ["<src>",... "<dest>"]
<dest>路徑的填寫(xiě)可以是容器內(nèi)的絕對(duì)路徑,也可以是相對(duì)于工作目錄的相對(duì)路徑
<src>可以是一個(gè)本地文件或者是一個(gè)本地壓縮文件,還可以是一個(gè)url
如果把<src>寫(xiě)成一個(gè)url,那么ADD就類(lèi)似于wget命令
如以下寫(xiě)法都是可以的:
ADD test relativeDir/ 
ADD test /relativeDir
ADD http://example.com/foobar /
盡量不要把<scr>寫(xiě)成一個(gè)文件夾,如果<src>是一個(gè)文件夾了,復(fù)制整個(gè)目錄的內(nèi)容,包括文件系統(tǒng)元數(shù)據(jù)
COPY
看這個(gè)名字就知道,又是一個(gè)復(fù)制命令
語(yǔ)法如下:
1. COPY <src>... <dest>
2. COPY ["<src>",... "<dest>"]
與ADD的區(qū)別
COPY的<src>只能是本地文件,其他用法一致
ENTRYPOINT
功能是啟動(dòng)時(shí)的默認(rèn)命令
語(yǔ)法如下:
1. ENTRYPOINT ["executable", "param1", "param2"]
2. ENTRYPOINT command param1 param2
如果從上到下看到這里的話,那么你應(yīng)該對(duì)這兩種語(yǔ)法很熟悉啦。
第二種就是寫(xiě)shell
第一種就是可執(zhí)行文件加參數(shù)
與CMD比較說(shuō)明(這倆命令太像了,而且還可以配合使用):
1. 相同點(diǎn):
只能寫(xiě)一條,如果寫(xiě)了多條,那么只有最后一條生效
容器啟動(dòng)時(shí)才運(yùn)行,運(yùn)行時(shí)機(jī)相同
2. 不同點(diǎn):
 ENTRYPOINT不會(huì)被運(yùn)行的command覆蓋,而CMD則會(huì)被覆蓋
 如果我們?cè)贒ockerfile種同時(shí)寫(xiě)了ENTRYPOINT和CMD,并且CMD指令不是一個(gè)完整的可執(zhí)行命令,那么CMD指定的內(nèi)容將會(huì)作為ENTRYPOINT的參數(shù)
如下:
FROM ubuntu
ENTRYPOINT ["top", "-b"]
CMD ["-c"]
如果我們?cè)贒ockerfile種同時(shí)寫(xiě)了ENTRYPOINT和CMD,并且CMD是一個(gè)完整的指令,那么它們兩個(gè)會(huì)互相覆蓋,誰(shuí)在最后誰(shuí)生效
如下:
FROM ubuntu
ENTRYPOINT ["top", "-b"]
CMD ls -al
那么將執(zhí)行l(wèi)s -al ,top -b不會(huì)執(zhí)行。
VOLUME
可實(shí)現(xiàn)掛載功能,可以將內(nèi)地文件夾或者其他容器種得文件夾掛在到這個(gè)容器種
語(yǔ)法為:
VOLUME ["/data"]
說(shuō)明:
   ["/data"]可以是一個(gè)JsonArray ,也可以是多個(gè)值。所以如下幾種寫(xiě)法都是正確的
VOLUME ["/var/log/"]
VOLUME /var/log
VOLUME /var/log /var/db
一般的使用場(chǎng)景為需要持久化存儲(chǔ)數(shù)據(jù)時(shí)
容器使用的是AUFS,這種文件系統(tǒng)不能持久化數(shù)據(jù),當(dāng)容器關(guān)閉后,所有的更改都會(huì)丟失。
所以當(dāng)數(shù)據(jù)需要持久化時(shí)用這個(gè)命令。
USER 
設(shè)置啟動(dòng)容器的用戶(hù),可以是用戶(hù)名或UID,所以,只有下面的兩種寫(xiě)法是正確的
USER daemo
USER UID
注意:如果設(shè)置了容器以daemon用戶(hù)去運(yùn)行,那么RUN, CMD 和 ENTRYPOINT 都會(huì)以這個(gè)用戶(hù)去運(yùn)行
 
WORKDIR
語(yǔ)法:
WORKDIR /path/to/workdir
設(shè)置工作目錄,對(duì)RUN,CMD,ENTRYPOINT,COPY,ADD生效。如果不存在則會(huì)創(chuàng)建,也可以設(shè)置多次。
如:
WORKDIR /a
WORKDIR b
WORKDIR c
RUN pwd
pwd執(zhí)行的結(jié)果是/a/b/c
WORKDIR也可以解析環(huán)境變量
如:
ENV DIRPATH /path
WORKDIR $DIRPATH/$DIRNAME
RUN pwd
pwd的執(zhí)行結(jié)果是/path/$DIRNAME
 
ARG
語(yǔ)法:
ARG <name>[=<default value>]
設(shè)置變量命令,ARG命令定義了一個(gè)變量,在docker build創(chuàng)建鏡像的時(shí)候,使用 --build-arg <varname>=<value>來(lái)指定參數(shù)
如果用戶(hù)在build鏡像時(shí)指定了一個(gè)參數(shù)沒(méi)有定義在Dockerfile種,那么將有一個(gè)Warning
提示如下:
[Warning] One or more build-args [foo] were not consumed.
我們可以定義一個(gè)或多個(gè)參數(shù),如下:
FROM busybox
ARG user1
ARG buildno
...
也可以給參數(shù)一個(gè)默認(rèn)值:
FROM busybox
ARG user1=someuser
ARG buildno=1
...
如果我們給了ARG定義的參數(shù)默認(rèn)值,那么當(dāng)build鏡像時(shí)沒(méi)有指定參數(shù)值,將會(huì)使用這個(gè)默認(rèn)值
 
ONBUILD
語(yǔ)法:
ONBUILD [INSTRUCTION]
這個(gè)命令只對(duì)當(dāng)前鏡像的子鏡像生效。
比如當(dāng)前鏡像為A,在Dockerfile種添加:
ONBUILD RUN ls -al
這個(gè) ls -al 命令不會(huì)在A鏡像構(gòu)建或啟動(dòng)的時(shí)候執(zhí)行
此時(shí)有一個(gè)鏡像B是基于A鏡像構(gòu)建的,那么這個(gè)ls -al 命令會(huì)在B鏡像構(gòu)建的時(shí)候被執(zhí)行。
 
STOPSIGNAL
語(yǔ)法:
STOPSIGNAL signal
STOPSIGNAL命令是的作用是當(dāng)容器推出時(shí)給系統(tǒng)發(fā)送什么樣的指令
 
HEALTHCHECK
 容器健康狀況檢查命令
語(yǔ)法有兩種:
1. HEALTHCHECK [OPTIONS] CMD command
2. HEALTHCHECK NONE
第一個(gè)的功能是在容器內(nèi)部運(yùn)行一個(gè)命令來(lái)檢查容器的健康狀況
第二個(gè)的功能是在基礎(chǔ)鏡像中取消健康檢查命令
[OPTIONS]的選項(xiàng)支持以下三中選項(xiàng):
    --interval=DURATION 兩次檢查默認(rèn)的時(shí)間間隔為30秒
    --timeout=DURATION 健康檢查命令運(yùn)行超時(shí)時(shí)長(zhǎng),默認(rèn)30秒
    --retries=N 當(dāng)連續(xù)失敗指定次數(shù)后,則容器被認(rèn)為是不健康的,狀態(tài)為unhealthy,默認(rèn)次數(shù)是3 
注意:
HEALTHCHECK命令只能出現(xiàn)一次,如果出現(xiàn)了多次,只有最后一個(gè)生效。
CMD后邊的命令的返回值決定了本次健康檢查是否成功,具體的返回值如下:
0: success - 表示容器是健康的
1: unhealthy - 表示容器已經(jīng)不能工作了
2: reserved - 保留值
例子:
HEALTHCHECK --interval=5m --timeout=3s \
CMD curl -f http://localhost/ || exit 1
健康檢查命令是:curl -f http://localhost/ || exit 1
兩次檢查的間隔時(shí)間是5秒
命令超時(shí)時(shí)間為3秒

posted on 2020-05-26 15:07 Benjamin 閱讀(288) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 雜談

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品一区二区男女羞羞无遮挡| 亚洲国产精品成人精品| 精品动漫3d一区二区三区免费版 | 一区二区三区不卡视频在线观看| 欧美成人免费大片| 欧美黄色小视频| 亚洲风情亚aⅴ在线发布| 美日韩精品免费观看视频| 久久久久国产精品麻豆ai换脸| 久久人人爽爽爽人久久久| 久久久久久久久久久一区| 久久激情五月婷婷| 欧美ab在线视频| 一区二区三区国产在线| 亚洲一区二区在线播放| 性欧美超级视频| 欧美激情亚洲综合一区| 欧美午夜不卡视频| 国产一区二区三区免费观看| 在线成人www免费观看视频| 夜夜嗨av一区二区三区中文字幕| 亚洲欧美成人精品| 老司机成人网| 99pao成人国产永久免费视频| 国外精品视频| 午夜老司机精品| 玖玖在线精品| 欧美亚男人的天堂| 黄色成人免费观看| 久久九九热re6这里有精品| 久久亚洲电影| 国产精品制服诱惑| av成人免费观看| 裸体女人亚洲精品一区| 亚洲网站啪啪| 欧美久久九九| 在线免费观看视频一区| 午夜国产欧美理论在线播放 | 亚洲欧美日韩另类精品一区二区三区| 久久婷婷综合激情| 亚洲在线观看视频| 国产精品白丝jk黑袜喷水| 亚洲精品欧美激情| 猛男gaygay欧美视频| 午夜亚洲激情| 国产精品日韩精品欧美在线 | 国产亚洲毛片| 欧美一级淫片aaaaaaa视频| 亚洲伦理自拍| 欧美刺激性大交免费视频| 国产综合欧美| 久久精品视频免费播放| 亚洲欧美另类在线观看| 国产精品video| 一区二区三区久久久| 亚洲欧洲美洲综合色网| 欧美11—12娇小xxxx| **网站欧美大片在线观看| 老司机凹凸av亚洲导航| 久久久亚洲午夜电影| 亚洲国产成人高清精品| 亚洲第一精品夜夜躁人人躁 | 亚洲欧美中文日韩v在线观看| 欧美三级网址| 亚洲图片在线观看| 亚洲午夜精品在线| 国产精品一区二区视频| 欧美中文字幕视频| 久久成人精品视频| 亚洲国产精品999| 亚洲高清中文字幕| 欧美日韩在线直播| 毛片一区二区| 亚洲韩国精品一区| 亚洲日本国产| 国产精品网站一区| 玖玖国产精品视频| 欧美激情影音先锋| 久久精品理论片| 欧美一进一出视频| 国语自产偷拍精品视频偷| 久久久久久久久一区二区| 欧美一区二区三区视频在线观看| 国产欧美日韩在线 | 玖玖玖免费嫩草在线影院一区| 欧美在线一级视频| 国产自产女人91一区在线观看| 亚洲摸下面视频| 国产日本欧美视频| 欧美影片第一页| 欧美日韩一区二区免费在线观看| 亚洲精品欧洲精品| 亚洲一二三四区| 在线成人性视频| 欧美午夜激情小视频| 久久久久久**毛片大全| 亚洲欧洲一区二区三区在线观看| 亚洲制服欧美中文字幕中文字幕| 欧美日韩一区自拍| 久久久夜色精品亚洲| 一区二区三区四区五区精品视频 | 亚洲精品系列| 久久免费国产精品1| 最新国产乱人伦偷精品免费网站 | 久久超碰97人人做人人爱| 久久久噜噜噜久久狠狠50岁| 中文久久精品| 欧美成人在线免费观看| 久久国产66| 欧美天堂亚洲电影院在线观看| 欧美国产日韩一区二区三区| 欧美专区在线播放| 欧美视频在线视频| 亚洲国产欧美一区二区三区同亚洲 | 亚洲精品一区在线观看| 国产手机视频一区二区| 99精品视频一区| 91久久精品网| 久久精品亚洲热| 欧美激情小视频| 久久久久久久波多野高潮日日| 欧美激情一区二区三区不卡| 中文精品视频一区二区在线观看| 欧美大片在线观看一区| 欧美国产精品日韩| 久久久久国产精品人| 欧美日韩中文在线| 最新中文字幕亚洲| 国产午夜一区二区三区| 欧美黄色网络| 一区二区亚洲精品| 午夜精品福利在线观看| 亚洲字幕在线观看| 欧美色图一区二区三区| 亚洲乱码国产乱码精品精天堂| 在线免费精品视频| 欧美在线你懂的| 久久裸体视频| 精品动漫3d一区二区三区| 欧美一区在线直播| 久久亚洲视频| 在线观看福利一区| 老司机成人网| 亚洲国产精品一区二区尤物区| 1769国产精品| 久久久亚洲精品一区二区三区 | 久久久久成人精品| 国产精品视区| 性欧美超级视频| 麻豆国产精品va在线观看不卡| 在线精品在线| 欧美精品v国产精品v日韩精品| 亚洲乱码一区二区| 午夜精品久久久久久| 国产日本欧洲亚洲| 久久久久久久999精品视频| 欧美电影在线| 亚洲性感激情| 国产一区二区成人| 暖暖成人免费视频| 一本色道久久综合精品竹菊 | 欧美午夜宅男影院在线观看| 在线亚洲观看| 久久亚洲图片| 9l国产精品久久久久麻豆| 国产精品美女久久| 久久精品一区四区| 亚洲精品视频在线观看网站| 亚洲欧美中文日韩v在线观看| 国产一区二区三区日韩| 欧美黄色aa电影| 性娇小13――14欧美| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲欧洲午夜| 国产麻豆精品久久一二三| 亚洲一区二区三区777| 欧美激情精品久久久久久大尺度| 99在线观看免费视频精品观看| 久久精品国产999大香线蕉| 亚洲黄色av一区| 国产精品日本欧美一区二区三区| 久久嫩草精品久久久精品| 在线视频精品一区| 欧美二区在线观看| 久久成人综合网| 亚洲少妇一区| 亚洲欧洲日夜超级视频| 国产欧美一区二区精品性色| 欧美人与性动交a欧美精品| 欧美专区18| 亚洲男人第一网站| 亚洲精品在线视频观看| 免费成人性网站| 久久久亚洲欧洲日产国码αv| 一级日韩一区在线观看| 亚洲电影网站| 国模精品一区二区三区| 国产精品久线观看视频| 欧美日韩国产麻豆| 欧美国产国产综合|