docker中run命令怎么用

這篇文章主要為大家展示了“docker中run命令怎么用”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學習一下“docker中run命令怎么用”這篇文章吧。

成都創(chuàng)新互聯(lián)公司專注于太和企業(yè)網(wǎng)站建設(shè),自適應網(wǎng)站建設(shè),商城網(wǎng)站定制開發(fā)。太和網(wǎng)站建設(shè)公司,為太和等地區(qū)提供建站服務。全流程按需定制網(wǎng)站,專業(yè)設(shè)計,全程項目跟蹤,成都創(chuàng)新互聯(lián)公司專業(yè)和態(tài)度為您提供的服務


首先看下命令格式:

docker run [OPTIONS] IMAGE[:TAG] [COMMAND] [ARG...]
  -d, --detach=false         指定容器運行于前臺還是后臺,默認為false     
  -i, --interactive=false   打開STDIN,用于控制臺交互    
  -t, --tty=false            分配tty設(shè)備,該可以支持終端登錄,默認為false    
  -u, --user=""              指定容器的用戶    
  -a, --attach=[]            登錄容器(必須是以docker run -d啟動的容器)  
  -w, --workdir=""           指定容器的工作目錄   
  -c, --cpu-shares=0        設(shè)置容器CPU權(quán)重,在CPU共享場景使用    
  -e, --env=[]               指定環(huán)境變量,容器中可以使用該環(huán)境變量    
  -m, --memory=""            指定容器的內(nèi)存上限    
  -P, --publish-all=false    指定容器暴露的端口    
  -p, --publish=[]           指定容器暴露的端口   
  -h, --hostname=""          指定容器的主機名    
  -v, --volume=[]            給容器掛載存儲卷,掛載到容器的某個目錄    
  --volumes-from=[]          給容器掛載其他容器上的卷,掛載到容器的某個目錄  
  --cap-add=[]               添加權(quán)限    
  --cap-drop=[]              刪除權(quán)限    
  --cidfile=""               運行容器后,在指定文件中寫入容器PID值,一種典型的監(jiān)控系統(tǒng)用法    
  --cpuset=""                設(shè)置容器可以使用哪些CPU,此參數(shù)可以用來容器獨占CPU    
  --device=[]                添加主機設(shè)備給容器,相當于設(shè)備直通    
  --DNS=[]                   指定容器的dns服務器    
  --dns-search=[]            指定容器的dns搜索域名,寫入到容器的/etc/resolv.conf文件    
  --entrypoint=""            覆蓋image的入口點    
  --env-file=[]              指定環(huán)境變量文件,文件格式為每行一個環(huán)境變量    
  --expose=[]                指定容器暴露的端口,即修改鏡像的暴露端口    
  --link=[]                  指定容器間的關(guān)聯(lián),使用其他容器的IP、env等信息    
  --lxc-conf=[]              指定容器的配置文件,只有在指定--exec-driver=lxc時使用    
  --name=""                  指定容器名字,后續(xù)可以通過名字進行容器管理,links特性需要使用名字    
  --net="bridge"             容器網(wǎng)絡設(shè)置:  
                             bridge 使用docker daemon指定的網(wǎng)橋       
                             host   //容器使用主機的網(wǎng)絡    
                             container:NAME_or_ID >//使用其他容器的網(wǎng)絡,共享IP和PORT等網(wǎng)絡資源    
                             none 容器使用自己的網(wǎng)絡(類似--net=bridge),但是不進行配置   
  --privileged=false         指定容器是否為特權(quán)容器,特權(quán)容器擁有所有的capabilities    
  --restart="no"             指定容器停止后的重啟策略:  
                             no:容器退出時不重啟    
                             on-failure:容器故障退出(返回值非零)時重啟   
                             always:容器退出時總是重啟    
  --rm=false                 指定容器停止后自動刪除容器(不支持以docker run -d啟動的容器)    
  --sig-proxy=true           設(shè)置由代理接受并處理信號,但是SIGCHLD、SIGSTOP和SIGKILL不能被代理

以上都是比較常用到的一些run的參數(shù)。

那么我們來舉一些常用例子。

案例1、運行一個簡單的容器,其中需要包含控制臺管理

[root@localhost ~]# docker run -i -t centos7.2
  • 這個容器一執(zhí)行就會進入到默認的線程”/bin/bash”,直接進入控制臺操作。當退出控制后后,容器會被終止。

案例2、運行一個在后臺執(zhí)行的容器,同時,還能用控制臺管理

[root@localhost ~]# docker run -d -i -t centos7.2

這個容器一執(zhí)行,會自動執(zhí)行默認的線程”/bin/bash”,但是不會讓你馬上進入控制臺操作。將會在后臺執(zhí)行,用docker ps 可以看到當前運行的控制臺。進入容器可是使用docker attach“Container name or id”。

案例3、運行一個帶命令在后臺不斷執(zhí)行的容器,不直接展示容器內(nèi)部信息

[root@localhost ~]# docker run -d centos7.2 ping www.baidu.com

這個容器將永久在后臺執(zhí)行,因為ping這個線程不會停止。除非你停止了ping的線程。

案例4、運行一個在后臺不斷執(zhí)行的容器,同時帶有命令,程序被終止后還能重啟繼續(xù)跑,還能用控制臺管理

[root@localhost ~]# docker run -d --restart=always centos7.2  ping www.baidu.com

這個容器將永久在后臺執(zhí)行,因為ping這個線程不會停止。如果你把ping這個線程終止了,那么容器會重啟繼續(xù)執(zhí)行ping功能

案例5、我們需要為容器指定一個名稱

[root@localhost ~]# docker run -d --name=server-db centos7.2 /usr/bin/MySQL_safe -d

這時候我們這個容器的名稱為server-db,同時激活了數(shù)據(jù)庫mysql的后臺線程,讓它不斷的跑,這時候我們的容器也不會被關(guān)閉。

案例6、我們需要讓server-http容器連接server-db容器

[root@localhost ~]#docker run -d --name=server-http --link=server-db  centos7.2 /usr/bin/httpd --DFOREGROUND

這時候,我們執(zhí)行了apache的服務器讓它不斷的在后臺執(zhí)行,同時,在php里配置mysql的服務器名稱為”server-db”,直接用server-db命名就可以了。不需要輸入ip地址之類的。我們的server-http指定連接了server-db。server-db在server-http里會被當做一個DNS解析來獲取相應的連接ip。

案例7、我們要將server-db,server-http的端口暴露出去,讓大家訪問

[root@localhost ~]#docker run -d --name=server-db -p 3306:3306 centos6.8-mysql /usr/bin/mysql_safe –d

這時候我們指定了服務器宿主機的3306端口映射到容器的3306端口,暴露出去。

[root@localhost ~]#docker run -d --name=server-http --link=server-db  -p 8080:80centos6.8-httpd /usr/bin/httpd --DFOREGROUND

這時候我們指定了服務器宿主機的8080端口映射到容器80端口,暴露出去。

案例8、我們要將宿主機的數(shù)據(jù)庫目錄/server/mysql-data掛載到server-db上

[root@localhost ~]#docker run -d --name=server-db -p 3306:3306 -v /server/mysql-data:/mysql-data centos6.8-mysql /usr/bin/mysql_safe –d

這時候,你會發(fā)現(xiàn),在server-db根目錄下你會發(fā)現(xiàn)有一個新的文件夾mysql-data,同時里面的文件內(nèi)容和宿主機下/server/mysql-data一樣。

案例9、我們希望一個容器在它的進程結(jié)束后,立馬自動刪除。

[root@localhost ~]# docker run -ti --rm centos7.2

以上是“docker中run命令怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

分享標題:docker中run命令怎么用
本文鏈接:http://bm7419.com/article14/jjdjge.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務器托管動態(tài)網(wǎng)站、網(wǎng)站策劃、網(wǎng)頁設(shè)計公司、微信小程序網(wǎng)站排名

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都app開發(fā)公司