本文列出了 Docker 使用過程中最常用的鏡像命令和容器命令,以及教大家如何操作容器數(shù)據(jù)卷,實(shí)現(xiàn)容器數(shù)據(jù)的備份。熟練練習(xí)這些命令以后,再來一些簡(jiǎn)單的應(yīng)用部署練習(xí),大家就可以學(xué)習(xí) Docker 的鏡像構(gòu)建、備份恢復(fù)遷移、鏡像倉(cāng)庫(kù)、網(wǎng)絡(luò)、集群等等更多的內(nèi)容。
鏡像相關(guān)命令
官方文檔:https://docs.docker.com/reference/
查看鏡像
[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
hello-world latest bf756fb1ae65 7 months ago 13.3kB
REPOSITORY
:鏡像在倉(cāng)庫(kù)中的名稱,本文中以后都簡(jiǎn)稱鏡像名稱
TAG
:鏡像標(biāo)簽
IMAGE ID
:鏡像 ID
CREATED
:鏡像的創(chuàng)建日期(不是獲取該鏡像的日期)
SIZE
:鏡像大小
這些鏡像都是存儲(chǔ)在 Docker 宿主機(jī)的 /var/lib/docker
目錄下。
搜索鏡像
如果你需要從網(wǎng)絡(luò)中查找需要的鏡像,可以通過以下命令搜索。

NAME
:鏡像名稱
DESCRIPTION
:鏡像描述
STARS
:用戶評(píng)價(jià),反映一個(gè)鏡像的受歡迎程度
OFFICIAL
:是否為官方構(gòu)建
AUTOMATED
:自動(dòng)構(gòu)建,表示該鏡像由 Docker Hub 自動(dòng)構(gòu)建流程創(chuàng)建的。
拉取鏡像
拉取鏡像就是從中央倉(cāng)庫(kù)下載鏡像到本地。
假如我要拉取 centos 鏡像到本地,如果不聲明 tag 鏡像標(biāo)簽信息則默認(rèn)拉取 latest 版本,也可以通過:https://hub.docker.com/ 搜索該鏡像,查看支持的 tag 信息。

通過查看 tag 信息,如果我們要下載 centos7 的鏡像。
刪除鏡像
按鏡像 ID 刪除鏡像。
# 刪除單個(gè)鏡像
docker rmi 鏡像ID
# 刪除多個(gè)鏡像
docker rmi 鏡像ID 鏡像ID 鏡像ID
docker images -q
可以查詢到所有鏡像的 ID,通過組合命令可以實(shí)現(xiàn)刪除所有鏡像的操作。
docker rmi `docker images -q`
注意:如果通過某個(gè)鏡像創(chuàng)建了容器,則該鏡像無法刪除。
解決辦法:先刪除鏡像中的容器,再刪除該鏡像。
容器相關(guān)命令
查看容器
查看正在運(yùn)行的容器。
[root@localhost ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
CONTAINER ID
:容器 ID
IMAGE
:所屬鏡像
COMMAND
:
CREATED
:創(chuàng)建時(shí)間
STATUS
:容器狀態(tài)
PORTS
:端口
NAMES
:容器名稱
查看停止的容器。
docker ps -f status=exited
查看所有容器(包括運(yùn)行和停止)。
查看最后一次運(yùn)行的容器。
創(chuàng)建與啟動(dòng)容器
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
-i
:表示運(yùn)行容器;
-t
:表示容器啟動(dòng)后會(huì)進(jìn)入其命令行。加入這兩個(gè)參數(shù)后,容器創(chuàng)建就能登錄進(jìn)去。即分配一個(gè)偽終端;
--name
:為創(chuàng)建的容器命名;
-v
:表示目錄映射關(guān)系(前者是宿主機(jī)目錄,后者是映射到宿主機(jī)上的目錄),可以使用多個(gè) -v 做多個(gè)目錄或文件映射。注意:最好做目錄映射,在宿主機(jī)上做修改,然后共享到容器上;
-d
:在 run 后面加上 -d 參數(shù),則會(huì)創(chuàng)建一個(gè)守護(hù)式容器在后臺(tái)運(yùn)行(這樣創(chuàng)建容器后不會(huì)自動(dòng)登錄容器,如果只加 -i -t 兩個(gè)參數(shù),創(chuàng)建容器后就會(huì)自動(dòng)進(jìn)容器里);
-p
:表示端口映射,前者是宿主機(jī)端口,后者是容器內(nèi)的映射端口??梢允褂枚鄠€(gè) -p 做多個(gè)端口映射。
-P
:隨機(jī)使用宿主機(jī)的可用端口與容器內(nèi)暴露的端口映射。
創(chuàng)建并進(jìn)入容器
下面這行命令的意思就是通過鏡像 AA 創(chuàng)建一個(gè)容器 BB,運(yùn)行容器并進(jìn)入容器的 /bin/bash
。
docker run -it --name 容器名稱 鏡像名稱:標(biāo)簽 /bin/bash
注意:Docker 容器運(yùn)行必須有一個(gè)前臺(tái)進(jìn)程, 如果沒有前臺(tái)進(jìn)程執(zhí)行,容器認(rèn)為是空閑狀態(tài),就會(huì)自動(dòng)退出。
退出當(dāng)前容器
守護(hù)式方式創(chuàng)建容器
docker run -di --name 容器名稱 鏡像名稱:標(biāo)簽
登錄守護(hù)式容器方式
docker exec -it 容器名稱|容器ID /bin/bash
停止與啟動(dòng)容器
# 停止容器
docker stop 容器名稱|容器ID
# 啟動(dòng)容器
docker start 容器名稱|容器ID
文件拷貝
如果我們需要將文件拷貝到容器內(nèi)可以使用 cp 命令。
docker cp 需要拷貝的文件或目錄 容器名稱:容器目錄
也可以將文件從容器內(nèi)拷貝出來。
docker cp 容器名稱:容器目錄 需要拷貝的文件或目錄
目錄掛載(容器數(shù)據(jù)卷操作)
我們可以在創(chuàng)建容器的時(shí)候,將宿主機(jī)的目錄與容器內(nèi)的目錄進(jìn)行映射,這樣我們就可以通過修改宿主機(jī)某個(gè)目錄的文件從而去影響容器,而且這個(gè)操作是雙向綁定的,也就是說容器內(nèi)的操作也會(huì)影響到宿主機(jī),實(shí)現(xiàn)備份功能。
但是容器被刪除的時(shí)候,宿主機(jī)的內(nèi)容并不會(huì)被刪除,因?yàn)榈讓邮峭ㄟ^拷貝實(shí)現(xiàn)的。如果多個(gè)容器掛載同一個(gè)目錄,其中一個(gè)容器被刪除,其他容器的內(nèi)容也不會(huì)受到影響,同理,底層是拷貝實(shí)現(xiàn)的。
但是容器被刪除的時(shí)候,宿主機(jī)的內(nèi)容并不會(huì)被刪除。如果多個(gè)容器掛載同一個(gè)目錄,其中一個(gè)容器被刪除,其他容器的內(nèi)容也不會(huì)受到影響。
容器與宿主機(jī)之間的數(shù)據(jù)卷屬于引用的關(guān)系,數(shù)據(jù)卷是從外界掛載到容器內(nèi)部中的,所以可以脫離容器的生命周期而獨(dú)立存在,正是由于數(shù)據(jù)卷的生命周期并不等同于容器的生命周期,在容器退出或者刪除以后,數(shù)據(jù)卷仍然不會(huì)受到影響,數(shù)據(jù)卷的生命周期會(huì)一直持續(xù)到?jīng)]有容器使用它為止。
創(chuàng)建容器添加 -v
參數(shù),格式為宿主機(jī)目錄:容器目錄
,例如:
docker run -di -v /mydata/docker_centos/data:/usr/local/data --name centos7-01 centos:7
# 多目錄掛載
docker run -di -v /宿主機(jī)目錄:/容器目錄 -v /宿主機(jī)目錄2:/容器目錄2 鏡像名
目錄掛載操作可能會(huì)出現(xiàn)權(quán)限不足的提示。這是因?yàn)?CentOS7 中的安全模塊 SELinux 把權(quán)限禁掉了,在 docker run 時(shí)通過 --privileged=true
給該容器加權(quán)限來解決掛載的目錄沒有權(quán)限的問題。
匿名掛載
匿名掛載只需要寫容器目錄即可,容器外對(duì)應(yīng)的目錄會(huì)在 /var/lib/docker/volume
中生成。
# 匿名掛載
docker run -di -v /usr/local/data --name centos7-02 centos:7
# 查看 volume 數(shù)據(jù)卷信息
docker volume ls

具名掛載
具名掛載就是給數(shù)據(jù)卷起了個(gè)名字,容器外對(duì)應(yīng)的目錄會(huì)在 /var/lib/docker/volume
中生成。
# 匿名掛載
docker run -di -v docker_centos_data:/usr/local/data --name centos7-03 centos:7
# 查看 volume 數(shù)據(jù)卷信息
docker volume ls

指定目錄掛載
一開始給大家講解的方式就屬于指定目錄掛載,這種方式的掛載不會(huì)在 /var/lib/docker/volume
目錄生成內(nèi)容。
docker run -di -v /mydata/docker_centos/data:/usr/local/data --name centos7-01 centos:7
# 多目錄掛載
docker run -di -v /宿主機(jī)目錄:/容器目錄 -v /宿主機(jī)目錄2:/容器目錄2 鏡像名
查看目錄掛載關(guān)系
通過 docker volume inspect 數(shù)據(jù)卷名稱
可以查看該數(shù)據(jù)卷對(duì)應(yīng)宿主機(jī)的目錄地址。
[root@localhost ~]# docker volume inspect docker_centos_data
[
{
"CreatedAt": "2020-08-13T20:19:51+08:00",
"Driver": "local",
"Labels": null,
"Mountpoint": "/var/lib/docker/volumes/docker_centos_data/_data",
"Name": "docker_centos_data",
"Options": null,
"Scope": "local"
}
]
通過 docker inspect 容器ID或名稱
,在返回的 JSON 節(jié)點(diǎn)中找到 Mounts
,可以查看詳細(xì)的數(shù)據(jù)掛載信息。

只讀/讀寫
# 只讀。只能通過修改宿主機(jī)內(nèi)容實(shí)現(xiàn)對(duì)容器的數(shù)據(jù)管理。
docker run -it -v /宿主機(jī)目錄:/容器目錄:ro 鏡像名
# 讀寫,默認(rèn)。宿主機(jī)和容器可以雙向操作數(shù)據(jù)。
docker run -it -v /宿主機(jī)目錄:/容器目錄:rw 鏡像名
volumes-from(繼承)
# 容器 centos7-01 指定目錄掛載
docker run -di -v /mydata/docker_centos/data:/usr/local/data --name centos7-01 centos:7
# 容器 centos7-04 和 centos7-05 相當(dāng)于繼承 centos7-01 容器的掛載目錄
docker run -di --volumes-from centos7-01 --name centos7-04 centos:7
docker run -di --volumes-from centos7-01 --name centos7-05 centos:7
查看容器 IP 地址
我們可以通過以下命令查看容器的元信息。
也可以直接執(zhí)行下面的命令直接輸出 IP 地址。
docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器名稱|容器ID
刪除容器
# 刪除指定容器
docker rm 容器名稱|容器ID
# 刪除多個(gè)容器
docker rm 容器名稱|容器ID 容器名稱|容器ID
之前給大家介紹過Docker run 命令的使用方法詳解,感興趣的朋友可以參考下!
到此這篇關(guān)于Docker 最常用的鏡像命令和容器命令詳解的文章就介紹到這了,更多相關(guān)Docker鏡像命令和容器命令內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!