使用Docker run的選項以覆蓋Dockerfile中的設置詳解
通常,我們首先定義Dockerfile文件,然后通過docker build命令構建得到鏡像文件。然后,才能夠基于鏡像文件通過docker run啟動一個容器的實例。
那么在啟動一個容器的時候,就可以改變鏡像文件中的一些參數(shù),而鏡像文件中的這些參數(shù)往往是通過Dockerfile文件定義的。
但并非Dockerfile文件中的所有定義都可以在啟動容器的時候被重新定義。docker run不能覆蓋的Dockerfile文件指令如下:
- FROM
- MAINTAINER
- RUN
- ADD
- COPY
1、覆蓋ENTRYPOINT指令
Dockerfile文件中的ENTRYPOINT指令,用以給出容器啟動后默認入口。
ENTRYPOINT指令給出容器啟動后的默認行為,一般難以在啟動容器時覆蓋,但是可以追加命令參數(shù)。示例如下:
docker run --entrypoint /bin/bash ...
,給出容器入口的后續(xù)命令參數(shù)docker run --entrypoint="/bin/bash ..." ...
,給出容器的新Shelldocker run -it --entrypoint="" mysql bash
,重置容器入口
2、覆蓋CMD指令
Dockerfile文件中的CMD指令,給出容器啟動后默認執(zhí)行的指令。
可以在啟動容器的時候,為docker run設置新的命令選項,從而覆蓋掉Dockerfile文件中的CMD指令(不會再咨詢Dockerfile文件中的CMD指令)。示例如下:
docker run ... <New_Command>
,可以給出其他命令以覆蓋Dockerfile文件中的默認指令
如果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指令,用以設置容器中的環(huán)境變量。
啟動容器時,自動為容器設置如下環(huán)境變量:
- HOME,基于USER設置用戶主目錄
- HOSTNAME,默認容器的主機名
- PATH,默認:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
- TERM,默認xterm,如果容器被分配了偽TTY
docker run可以方便地覆蓋該指令。示例如下:
docker run -e "key=value" ...
,設置新的環(huán)境變量key
docker run -h ...
,覆蓋HOSTNAME
docker 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"
通過腳本,設置或覆蓋環(huán)境變量
5、覆蓋VOLUME指令
Dockerfile文件中的VOLUME指令,用以為容器設置的data volumes。
docker run -v ...
docker run -volumes-from ...
6、覆蓋USER指令
容器內部的默認用戶是root(uid=0)。
Dockerfile文件中可以通過USER指定其他用戶為容器的默認用戶。
docker run -u="" ...
docker run --user="" ...
docker run支持-u如下形式:
- user
- user:group
- uid
- uid:gid
- user:gid
- uid:group
7、覆蓋WORKDIR指令
Dockerfile文件中的WORKDIR指令,用以為后續(xù)指令設置工作目錄。
如果設置的路徑不存在,則創(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/
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接
相關文章
docker?部署hbase并且java?Api連接的操作過程
這篇文章主要介紹了docker?部署hbase并且java?Api連接的操作過程,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-11-11如何運用docker配合python開發(fā)環(huán)境實例
本篇文章主要介紹了如何運用docker配合python開發(fā)實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07使用 docker部署tomcat并接入skywalking的使用
這里主要介紹了使用 docker 部署 tomact 并接入 skywalking 的使用,因為在網(wǎng)上并沒有查到太多相關的信息,所以這里記錄下來,需要對有需求的小伙伴提供一些幫助2021-04-04解決docker run中使用 ./ 相對路徑掛載文件或目錄失敗的問題
這篇文章主要介紹了解決docker run中使用‘./‘相對路徑掛載文件或目錄失敗的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-03-03docker-compose部署zk+kafka+storm集群的實現(xiàn)
這篇文章主要介紹了docker-compose部署zk+kafka+storm集群,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-10-10使用Docker安裝Nginx并配置端口轉發(fā)問題及解決方法
這篇文章主要介紹了使用Docker安裝Nginx并配置端口轉發(fā),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-01-01