docker run 參數(shù)詳解

命令格式:docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
Usage: Run a command in a new container
中文意思為:通過run命令創(chuàng)建一個新的容器(container)

  • 常用選項說明
    • -d, --detach=false, 指定容器運行于前臺還是后臺,默認(rèn)為false
    • -i, --interactive=false, 打開STDIN,用于控制臺交互
    • -t, --tty=false, 分配tty設(shè)備,該可以支持終端登錄,默認(rèn)為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)限,權(quán)限清單詳見:http://linux.die.net/man/7/capabilities
    • --cap-drop=[], 刪除權(quán)限,權(quán)限清單詳見:http://linux.die.net/man/7/capabilities
    • --cidfile="", 運行容器后,在指定文件中寫入容器PID值,一種典型的監(jiān)控系統(tǒng)用法
    • --cpuset="", 設(shè)置容器可以使用哪些CPU,此參數(shù)可以用來容器獨占CPU
    • --device=[], 添加主機設(shè)備給容器,相當(dāng)于設(shè)備直通
    • --dns=[], 指定容器的dns服務(wù)器
    • --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)絡(luò)設(shè)置:
      • bridge 使用docker daemon指定的網(wǎng)橋
      • host //容器使用主機的網(wǎng)絡(luò)
      • container:NAME_or_ID >//使用其他容器的網(wǎng)路,共享IP和PORT等網(wǎng)絡(luò)資源
      • none 容器使用自己的網(wǎng)絡(luò)(類似--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不能被代理

示例

  • 運行一個在后臺執(zhí)行的容器,同時,還能用控制臺管理:docker run -i -t -d ubuntu:latest
  • 運行一個帶命令在后臺不斷執(zhí)行的容器,不直接展示容器內(nèi)部信息:docker run -d ubuntu:latest ping www.docker.com
  • 運行一個在后臺不斷執(zhí)行的容器,同時帶有命令,程序被終止后還能重啟繼續(xù)跑,還能用控制臺管理,docker run -d --restart=always ubuntu:latest ping www.docker.com
  • 為容器指定一個名字,docker run -d --name=ubuntu_server ubuntu:latest
  • 容器暴露80端口,并指定宿主機80端口與其通信(: 之前是宿主機端口,之后是容器需暴露的端口),docker run -d --name=ubuntu_server -p 80:80 ubuntu:latest
  • 指定容器內(nèi)目錄與宿主機目錄共享(: 之前是宿主機文件夾,之后是容器需共享的文件夾),docker run -d --name=ubuntu_server -v /etc/www:/var/www ubuntu:latest

docker run -d -i -t --net="bridge" -p 8001:80 -p 8081:80 --name centos_latest -v /www/wwwroot/DockerFile:/www centos

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容