docker run
# 運(yùn)行一個容器
docker run -it -p 8088:8088 -p 8089:8089 -p 8090:9090 -v /root/soft/docker:/root/soft/docker -v /root/soft/dockertt:/root/soft/dockertt loen/rc /bin/bash
命令的格式:
Usage: docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
-a, --attach=[] 登錄容器(以docker run -d啟動的容器)
-c, --cpu-shares=0 設(shè)置容器CPU權(quán)重,在CPU共享場景使用
--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="" 運(yùn)行容器后,在指定文件中寫入容器PID值,一種典型的監(jiān)控系統(tǒng)用法
--cpuset="" 設(shè)置容器可以使用哪些CPU,此參數(shù)可以用來容器獨(dú)占CPU
-d, --detach=false 指定容器運(yùn)行于前臺還是后臺
--device=[] 添加主機(jī)設(shè)備給容器,相當(dāng)于設(shè)備直通
--dns=[] 指定容器的dns服務(wù)器
--dns-search=[] 指定容器的dns搜索域名,寫入到容器的/etc/resolv.conf文件
-e, --env=[] 指定環(huán)境變量,容器中可以使用該環(huán)境變量
--entrypoint="" 覆蓋image的入口點(diǎn)
--env-file=[] 指定環(huán)境變量文件,文件格式為每行一個環(huán)境變量
--expose=[] 指定容器暴露的端口,即修改鏡像的暴露端口
-h, --hostname="" 指定容器的主機(jī)名
-i, --interactive=false 打開STDIN,用于控制臺交互
--link=[] 指定容器間的關(guān)聯(lián),使用其他容器的IP、env等信息
--lxc-conf=[] 指定容器的配置文件,只有在指定--exec-driver=lxc時使用
-m, --memory="" 指定容器的內(nèi)存上限
--name="" 指定容器名字,后續(xù)可以通過名字進(jìn)行容器管理,links特性需要使用名字
--net="bridge" 容器網(wǎng)絡(luò)設(shè)置,待詳述
-P, --publish-all=false 指定容器暴露的端口,待詳述
-p, --publish=[] 指定容器暴露的端口,待詳述
--privileged=false 指定容器是否為特權(quán)容器,特權(quán)容器擁有所有的capabilities
--restart="" 指定容器停止后的重啟策略,待詳述
--rm=false 指定容器停止后自動刪除容器(不支持以docker run -d啟動的容器)
--sig-proxy=true 設(shè)置由代理接受并處理信號,但是SIGCHLD、SIGSTOP和SIGKILL不能被代理
-t, --tty=false 分配tty設(shè)備,該可以支持終端登錄
-u, --user="" 指定容器的用戶
-v, --volume=[] 給容器掛載存儲卷,掛載到容器的某個目錄
--volumes-from=[] 給容器掛載其他容器上的卷,掛載到容器的某個目錄
-w, --workdir="" 指定容器的工作目錄
>>>>>> 詳細(xì)講解
端口暴露
-P參數(shù):docker自動映射暴露端口;
docker run -d -P training/webapp <span style="color:#009900;">//docker自動在host上打開49000到49900的端口,映射到容器(由鏡像指定,或者--expose參數(shù)指定)的暴露端口;</span>
-p參數(shù):指定端口或IP進(jìn)行映射;
docker run -d -p 5000:80 training/webapp <span style="color:#009900;">//host上5000號端口,映射到容器暴露的80端口;</span>
docker run -d -p 127.0.0.1:5000:80 training/webapp <span style="color:#009900;">//host上127.0.0.1:5000號端口,映射到容器暴露的80端口;</span>
docker run -d -p 127.0.0.1::5000 training/webapp <span style="color:#009900;">//host上127.0.0.1:隨機(jī)端口,映射到容器暴露的80端口;</span>
docker run -d -p 127.0.0.1:5000:5000/udp training/webapp <span style="color:#009900;">//綁定udp端口;</span>
網(wǎng)絡(luò)配置
--net=bridge: <span style="color:#009900;">//使用docker daemon指定的網(wǎng)橋</span>
--net=host: <span style="color:#009900;">//容器使用主機(jī)的網(wǎng)絡(luò)</span>
--net=container:NAME_or_ID:<span style="color:#009900;">//使用其他容器的網(wǎng)路,共享IP和PORT等網(wǎng)絡(luò)資源</span>
--net=none: <span style="color:#009900;">//容器使用自己的網(wǎng)絡(luò)(類似--net=bridge),但是不進(jìn)行配置</span>
docker stop
# 關(guān)閉運(yùn)行中的容器
docker stop 容器ID
docker start
# 啟動一個已經(jīng)停止的容器
docker start 容器ID
# 重啟一個容器
docker restart 容器ID
docker attach
# 進(jìn)入一個運(yùn)行中的容器
docker attach 容器ID
docker ps
# 顯示全部容器
docker ps -a
# 顯示當(dāng)前運(yùn)行的容器
docker ps
docker images
# 查看本地鏡像
docker images
docker rmi
# 刪除所有鏡像
docker rmi $(docker images | grep -v RESPOSITORY | awk '{print $3}')
docker build
# 構(gòu)建容器
docker build -t 鏡像名稱 . # 后面的. 指的是當(dāng)前文件夾 (其實(shí)是Dockerfile存放的文件夾)
# 建立映像文件。–rm 選項(xiàng)是告訴Docker,在構(gòu)建完成后刪除臨時的Container,Dockerfile的每一行指令都會創(chuàng)建一個臨時的Container,一般這些臨時生成的Container是不需要的
docker build --rm=true -t loen/lamp .
docker rm
# 刪除容器
docker rm 容器ID
# 刪除所有容器
docker rm $(docker ps -a)
docker history
# 查看歷史
docker history 鏡像ID
docker export
# 導(dǎo)出容器
docker export 容器ID > xxx.tar
docker save
# 把 mynewimage 鏡像保存成 tar 文件
docker save myimage | bzip2 -9 -c> /home/save.tar.bz2
docker load
# 加載 myimage 鏡像
bzip2 -d -c < /home/save.tar.bz2 | docker load
更多建議: