使用Docker run的選項以覆蓋Dockerfile中的設(shè)置詳解
通常,我們首先定義Dockerfile文件,然后通過docker build命令構(gòu)建得到鏡像文件。然后,才能夠基于鏡像文件通過docker run啟動一個容器的實例。
那么在啟動一個容器的時候,就可以改變鏡像文件中的一些參數(shù),而鏡像文件中的這些參數(shù)往往是通過Dockerfile文件定義的。
但并非Dockerfile文件中的所有定義都可以在啟動容器的時候被重新定義。docker run不能覆蓋的Dockerfile文件指令如下:
- FROM
- MAINTAINER
- RUN
- ADD
- COPY
1、覆蓋ENTRYPOINT指令
Dockerfile文件中的ENTRYPOINT指令,用以給出容器啟動后默認(rèn)入口。
ENTRYPOINT指令給出容器啟動后的默認(rèn)行為,一般難以在啟動容器時覆蓋,但是可以追加命令參數(shù)。示例如下:
docker run --entrypoint /bin/bash ...
,給出容器入口的后續(xù)命令參數(shù)docker run --entrypoint="/bin/bash ..." ...
,給出容器的新Shelldocker run -it --entrypoint="" mysql bash
,重置容器入口
2、覆蓋CMD指令
Dockerfile文件中的CMD指令,給出容器啟動后默認(rèn)執(zhí)行的指令。
可以在啟動容器的時候,為docker run設(shè)置新的命令選項,從而覆蓋掉Dockerfile文件中的CMD指令(不會再咨詢Dockerfile文件中的CMD指令)。示例如下:
docker run ... <New_Command>
,可以給出其他命令以覆蓋Dockerfile文件中的默認(rèn)指令
如果Dockerfile文件中還聲明了ENTRYPOINT指令,則上述指令都將作為參數(shù)追加到ENTRYPOINT指令。
3、覆蓋EXPOSE指令
Dockerfile文件中的EXPOSE指令,用以向容器所在主機保留端口。
顯然這是運行時容器的一個特性,所以docker run可以方便地覆蓋該指令。示例如下:
docker run --expose="port_number:port_number"
docker run -p port_number:port_number/tcp
,打開指定范圍的端口docker run --link="another_container_id"
,鏈接到其他容器docker run -P
,打開所有端口
4、覆蓋ENV指令
Dockerfile文件中的ENV指令,用以設(shè)置容器中的環(huán)境變量。
啟動容器時,自動為容器設(shè)置如下環(huán)境變量:
- HOME,基于USER設(shè)置用戶主目錄
- HOSTNAME,默認(rèn)容器的主機名
- PATH,默認(rèn):/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
- TERM,默認(rèn)xterm,如果容器被分配了偽TTY
docker run可以方便地覆蓋該指令。示例如下:
docker run -e "key=value" ...
,設(shè)置新的環(huán)境變量keydocker run -h ...
,覆蓋HOSTNAMEdocker run ubuntu /bin/bash -c export
declare -x HOME="/" declare -x HOSTNAME="85bc26a0e200" declare -x OLDPWD declare -x PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" declare -x PWD="/" declare -x SHLVL="1" declare -x deep="purple"
通過腳本,設(shè)置或覆蓋環(huán)境變量
5、覆蓋VOLUME指令
Dockerfile文件中的VOLUME指令,用以為容器設(shè)置的data volumes。
docker run -v ...
docker run -volumes-from ...
6、覆蓋USER指令
容器內(nèi)部的默認(rèn)用戶是root(uid=0)。
Dockerfile文件中可以通過USER指定其他用戶為容器的默認(rèn)用戶。
docker run -u="" ...
docker run --user="" ...
docker run支持-u如下形式:
- user
- user:group
- uid
- uid:gid
- user:gid
- uid:group
7、覆蓋WORKDIR指令
Dockerfile文件中的WORKDIR指令,用以為后續(xù)指令設(shè)置工作目錄。
如果設(shè)置的路徑不存在,則創(chuàng)建該路徑,即時在后續(xù)指令中根本未使用。
在一個,可以存在多個WORKDIR。對于相對路徑,后續(xù)指令繼承前續(xù)指令。
在WORKDIR中,可以引用前續(xù)已經(jīng)定義的環(huán)境變量。
docker run -w="" ...
docker run --workdir="" ...
參考鏈接:
https://docs.docker.com/engine/reference/run/
https://docs.docker.com/engine/reference/builder/
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對本站的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。