docker容器的常用命令

docker有很多命令,讓我們一個一個全部背下來,基本是不可能的,幫助文件的作用就很大了,想要查詢那個命令,直接去找幫助文件,幫助文件地址:https://docs.docker.com/reference/ , 在docker文件中列出了多有命令的用法。

docker命令有幾種,最常見的是映象命令,容器命令。下來就來看看常用的docker命令。

一.通用命令

docker --help 命令----可以快速檢視命令的用法

用法:    docker [OPTIONS] COMMAND

二. 映象的基本命令

我們可以通過docker images --help檢視所有的docker 映象相關的命令

1. 列出本機上所有的映象

docker images

-a : 列出本地所有的映象(含中間映象層) 表示的是all的含義
-q : 只顯示映象ID
--digests: 顯示映象的摘要資訊
--no-trunc:顯示完整的映象資訊
docker images -q : 查詢映象的ID

docker images -qa: 查詢所有映象的id, 可以批量刪除時使用

docker images --no-trunc

2. 搜尋映象

docker search 映象名

--filter=stars=3: 列出點贊數不小於指定數值的映象

--no-trunc: 顯示完整的映象描述
--automated: 只列出automated build型別的映象


3. 拉取映象

docker pull 映象名稱[:tag]
tag是可選項, 不填表示latest Using default tag: latest # 指定使用的映象
latest: Pulling from library/mysql
a330b6cecb98: Pull complete # 逐層拉取
9c8f656c32b8: Pull complete
88e473c3f553: Pull complete
062463ea5d2f: Pull complete
daf7e3bdf4b6: Pull complete
1839c0b7aac9: Pull complete
cf0a0cfee6d0: Pull complete
1b42041bb11e: Pull complete
10459d86c7e6: Pull complete
b7199599d5f9: Pull complete
1d6f51e17d45: Pull complete
50e0789bacad: Pull complete
Digest: sha256:99e0989e7e3797cfbdb8d51a19d32c8d286dd8862794d01a547651a896bcf00c #映象的簽名
Status: Downloaded newer image for mysql:latest
docker.io/library/mysql:latest # 映象的真實地址 docker pull mysql
docker pull docker.io/library/mysql:latest
這兩個是一回事

4. 刪除映象

docker rmi 映象名稱:tag

刪除正在執行的映象

docker rmi -f hello-world

刪除全部映象

docker rmi -f ${docker images -qa}
docker images -qa 是查詢當前全部映象的id, 然後刪除這些映象

三. 容器的基本命令

1. 執行容器

### docker run -p 8080:80 -d daocloud.io/nginx
docker run是啟動容器. 啟動的時候, 現在本地查詢映象, 如果本地沒有, 則去網路下載
--name: 容器名字
-d: 表示以後臺程序執行.
-p 8080:80 是把虛擬機器中啟動的nginx的埠號80 對映到本機的8080
-P: 隨機埠對映
-i: 以互動模式執行容器, 通常與-t同時使用
-t: 為容器重新分配一個偽輸入終端, 通常與-i同時使用
-it: 使用互動方式執行,進入容器檢視內容

啟動並執行容器

docker run -it centos /bin/bash

2. 查詢正在執行的容器

### docker ps
-a: 列出歷史執行過的所有容器 + 當前正在執行的容器
-l: 顯示最近建立的容器
-n: 顯示最近n個建立的容器
-q: 靜默模式, 只顯示容器編號
--no-trunc: 不截斷輸出

3. 在本機和容器之間拷貝檔案

如: 拷貝index.html替換nginx的預設index.html頁面

docker cp ./index.html 1a2aa74fb4e5://usr/share/nginx/html

4. 啟動容器

啟動已經停止的容器

docker start

重啟容器

docker restart

後臺啟動容器

docker run -d centos

這塊有一個坑

[root@iZ2ze8f268fd4hso5clji8Z ~]# docker run -d centos

8671b9255fcb2f72751a0bf0d24c9d52195c7b6aae9bab05b4e392b830bfc5e5

[root@iZ2ze8f268fd4hso5clji8Z ~]# docker ps

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

[root@iZ2ze8f268fd4hso5clji8Z ~]# docker ps -a

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

8671b9255fcb centos "/bin/bash" 7 seconds ago Exited (0) 6 seconds ago stupefied_zhukovsky

通過-d啟動了docker,可是docker ps檢視的時候, 發現沒有啟動,這是什麼原因?

這是因為docker認為這個容器沒有人使用, 所以停止了。

注意:docker啟動一個後臺程序,必須要有一個前臺程序呼叫它。否則,docker發現沒有被使用,就會自動停止他。

nginx伺服器就是這樣,容器啟動後發現自己沒有服務,就會立刻停止。

5.停止docker容器

docker stop 容器id

6.查詢容器日誌

docker logs 

-f								跟蹤日誌輸出
-t 列印時間戳
-n 或者 --tail 列印日誌的行數

查詢日誌:

docker logs -ft --tail 10 容器名

案例:
後臺啟動centos,然後不停的列印日誌。 然後通過docker logs查詢日誌
[root@iZ2ze8f268fd4hso5clji8Z ~]# docker run -d centos /bin/bash -c "while true; do echo test; sleep 1; done"
730ee45df27df144eb7533d1f5b0676c79fac68546e84dfff7ba9b2a16f933e2 [root@iZ2ze8f268fd4hso5clji8Z ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
730ee45df27d centos "/bin/bash -c 'while…" 4 seconds ago Up 3 seconds crazy_heisenberg [root@iZ2ze8f268fd4hso5clji8Z ~]# docker logs -ft -n 10 730ee45df27d
2021-09-27T11:43:45.214069586Z test
2021-09-27T11:43:46.215681065Z test
2021-09-27T11:43:47.217170501Z test
2021-09-27T11:43:48.218729587Z test

7. 檢視容器中的程序

命令: docker top 容器id

[root@iZ2ze8f268fd4hso5clji8Z ~]# docker top 730ee45df27d
UID PID PPID C STIME TTY
root 40908 40888 0 19:43 ?
root 41183 40908 0 19:47 ?

8. 檢視映象的元資料

命令: docker inspect 容器id

測試
[root@iZ2ze8f268fd4hso5clji8Z ~]# docker inspect 730ee45df27d
[
{
"Id": "730ee45df27df144eb7533d1f5b0676c79fac68546e84dfff7ba9b2a16f933e2",
"Created": "2021-09-27T11:43:36.761377838Z",
"Path": "/bin/bash",
"Args": [
"-c",
"while true; do echo test; sleep 1; done"
],
"State": {
"Status": "running",
"Running": true,
"Paused": false,
"Restarting": false,
"OOMKilled": false,
"Dead": false,
"Pid": 40908,
"ExitCode": 0,
"Error": "",
"StartedAt": "2021-09-27T11:43:37.203100727Z",
"FinishedAt": "0001-01-01T00:00:00Z"
},
"Image": "sha256:5d0da3dc976460b72c77d94c8a1ad043720b0416bfc16c52c45d4847e53fadb6",
"ResolvConfPath": "/var/lib/docker/containers/730ee45df27df144eb7533d1f5b0676c79fac68546e84dfff7ba9b2a16f933e2/resolv.conf",
"HostnamePath": "/var/lib/docker/containers/730ee45df27df144eb7533d1f5b0676c79fac68546e84dfff7ba9b2a16f933e2/hostname",
"HostsPath": "/var/lib/docker/containers/730ee45df27df144eb7533d1f5b0676c79fac68546e84dfff7ba9b2a16f933e2/hosts",
"LogPath": "/var/lib/docker/containers/730ee45df27df144eb7533d1f5b0676c79fac68546e84dfff7ba9b2a16f933e2/730ee45df27df144eb7533d1f5b0676c79fac68546e84dfff7ba9b2a16f933e2-json.log",
"Name": "/crazy_heisenberg",
"RestartCount": 0,
"Driver": "overlay2",
"Platform": "linux",
"MountLabel": "",
"ProcessLabel": "",
"AppArmorProfile": "",
"ExecIDs": null,
"HostConfig": {
"Binds": null,
"ContainerIDFile": "",
"LogConfig": {
"Type": "json-file",
"Config": {}
},
"NetworkMode": "default",
"PortBindings": {},
"RestartPolicy": {
"Name": "no",
"MaximumRetryCount": 0
},
"AutoRemove": false,
"VolumeDriver": "",
"VolumesFrom": null,
"CapAdd": null,
"CapDrop": null,
"CgroupnsMode": "host",
"Dns": [],
"DnsOptions": [],
"DnsSearch": [],
"ExtraHosts": null,
"GroupAdd": null,
"IpcMode": "private",
"Cgroup": "",
"Links": null,
"OomScoreAdj": 0,
"PidMode": "",
"Privileged": false,
"PublishAllPorts": false,
"ReadonlyRootfs": false,
"SecurityOpt": null,
"UTSMode": "",
"UsernsMode": "",
"ShmSize": 67108864,
"Runtime": "runc",
"ConsoleSize": [
0,
0
],
"Isolation": "",
"CpuShares": 0,
"Memory": 0,
"NanoCpus": 0,
"CgroupParent": "",
"BlkioWeight": 0,
"BlkioWeightDevice": [],
"BlkioDeviceReadBps": null,
"BlkioDeviceWriteBps": null,
"BlkioDeviceReadIOps": null,
"BlkioDeviceWriteIOps": null,
"CpuPeriod": 0,
"CpuQuota": 0,
"CpuRealtimePeriod": 0,
"CpuRealtimeRuntime": 0,
"CpusetCpus": "",
"CpusetMems": "",
"Devices": [],
"DeviceCgroupRules": null,
"DeviceRequests": null,
"KernelMemory": 0,
"KernelMemoryTCP": 0,
"MemoryReservation": 0,
"MemorySwap": 0,
"MemorySwappiness": null,
"OomKillDisable": false,
"PidsLimit": null,
"Ulimits": null,
"CpuCount": 0,
"CpuPercent": 0,
"IOMaximumIOps": 0,
"IOMaximumBandwidth": 0,
"MaskedPaths": [
"/proc/asound",
"/proc/acpi",
"/proc/kcore",
"/proc/keys",
"/proc/latency_stats",
"/proc/timer_list",
"/proc/timer_stats",
"/proc/sched_debug",
"/proc/scsi",
"/sys/firmware"
],
"ReadonlyPaths": [
"/proc/bus",
"/proc/fs",
"/proc/irq",
"/proc/sys",
"/proc/sysrq-trigger"
]
},
"GraphDriver": {
"Data": {
"LowerDir": "/var/lib/docker/overlay2/6f2a5b4f663926bceeef1e22e3181367ca9c7e30980f27a49d81a2f5f7d10032-init/diff:/var/lib/docker/overlay2/5bd0304415d4744ae90a7472c8b54e5b21b91b2a2487350f9783cca03fde0422/diff",
"MergedDir": "/var/lib/docker/overlay2/6f2a5b4f663926bceeef1e22e3181367ca9c7e30980f27a49d81a2f5f7d10032/merged",
"UpperDir": "/var/lib/docker/overlay2/6f2a5b4f663926bceeef1e22e3181367ca9c7e30980f27a49d81a2f5f7d10032/diff",
"WorkDir": "/var/lib/docker/overlay2/6f2a5b4f663926bceeef1e22e3181367ca9c7e30980f27a49d81a2f5f7d10032/work"
},
"Name": "overlay2"
},
"Mounts": [],
"Config": {
"Hostname": "730ee45df27d",
"Domainname": "",
"User": "",
"AttachStdin": false,
"AttachStdout": false,
"AttachStderr": false,
"Tty": false,
"OpenStdin": false,
"StdinOnce": false,
"Env": [
"PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
],
"Cmd": [
"/bin/bash",
"-c",
"while true; do echo test; sleep 1; done"
],
"Image": "centos",
"Volumes": null,
"WorkingDir": "",
"Entrypoint": null,
"OnBuild": null,
"Labels": {
"org.label-schema.build-date": "20210915",
"org.label-schema.license": "GPLv2",
"org.label-schema.name": "CentOS Base Image",
"org.label-schema.schema-version": "1.0",
"org.label-schema.vendor": "CentOS"
}
},
"NetworkSettings": {
"Bridge": "",
"SandboxID": "ab23a522803ad96e35a57d9a012e8339c271eec859041800e285e46248d09731",
"HairpinMode": false,
"LinkLocalIPv6Address": "",
"LinkLocalIPv6PrefixLen": 0,
"Ports": {},
"SandboxKey": "/var/run/docker/netns/ab23a522803a",
"SecondaryIPAddresses": null,
"SecondaryIPv6Addresses": null,
"EndpointID": "17e1e833c474ead88be155d7f14736d1e6330b95ece4eed0d6988272b170c204",
"Gateway": "172.17.0.1",
"GlobalIPv6Address": "",
"GlobalIPv6PrefixLen": 0,
"IPAddress": "172.17.0.2",
"IPPrefixLen": 16,
"IPv6Gateway": "",
"MacAddress": "02:42:ac:11:00:02",
"Networks": {
"bridge": {
"IPAMConfig": null,
"Links": null,
"Aliases": null,
"NetworkID": "e77f06f74488d7f8cc7b38311a435c88d18508a786d650ca49a1774df7a2bf28",
"EndpointID": "17e1e833c474ead88be155d7f14736d1e6330b95ece4eed0d6988272b170c204",
"Gateway": "172.17.0.1",
"IPAddress": "172.17.0.2",
"IPPrefixLen": 16,
"IPv6Gateway": "",
"GlobalIPv6Address": "",
"GlobalIPv6PrefixLen": 0,
"MacAddress": "02:42:ac:11:00:02",
"DriverOpts": null
}
}
}
}
]

這裡面的資訊有很多

9. 儲存改動為新的image

docker commit -m 'fun' 2a2f3a5c960f fun-nginx

這段程式碼的含義是, 提交對docker容器所做的修改, 並起了一個名字叫fun. 容器的名字叫fun-nginx.

執行完這段程式碼以後, 會重新生成一個新的映象.

我們來看看現在有幾個nginx的映象

現在有兩個映象, 其中fun-nginx是我們剛建的. 我們可以刪除一個.

10. 退出容器

exit: 容器停止退出

ctrl+P+Q: 容器不停止退出

11.刪除容器

刪除沒有執行的容器

docker rm 容器id1 容器id2 ....

刪除正在執行的容器

docker rm -f 容器名

刪除所有的容器

docker rm -f $(docker ps -aq)

四. 重要

1. 啟動守護式容器

docker run -d 容器名
在後臺程序中啟動

使用守護程序的方式啟動容器, 會有一個問題: 使用docker ps -a, 發現容器已經退出

重點: docker容器後臺執行, 就必須有一個前臺程序, 容器執行的命令如果不是那些一直掛起的命令(比如top, tail), 就會自動退出. 這個是docker的機制, 比如web容器, 以nginx為例, 正常情況下,我們配置啟動服務只需要啟動相應的service即可, 例如: service nginx start. 但是, 這樣做, nginx為後臺模式執行, 就導致docker前臺沒有執行的應用. 這樣的容器後臺啟動後, 會立即自殺, 因為他覺得沒喲碃可以做. 所以, 最佳的的解決方案是, 將你要執行的程式以前臺程序的形式執行

docker run -d nginx /bin/sh -c "while true; do echo hello zzyy; sleep 2; done"

在控制檯持續輸出hello zzyy, 2秒鐘列印一次

2. 檢視容器日誌

docker logs -f -t --tail 數字 容器ID

-t: 是加入時間戳
-f: 跟隨最新的日誌列印
--tail 數字: 顯示最多多少條

3. 檢視容器內執行的程序

docker top 容器id

4. 檢視容器內部的細節

docker inspect 容器ID

docker容器內部是洋蔥環,一層套一層. inspect就是檢視容器內部的細節的

5. 進入正在執行的容器並以命令列互動

進入正在執行的容器: docker exec -it 容器ID bashShell
重新進入: docker attach 容器ID
上述二者的區別:

舉例: 現在執行一個容器

docker run -d

進入到了容器裡面, 想要退出的話ctr + c

在想要進入到這個容器, 進入的是容器的根目錄

 docker attach 容器ID

使用exec執行容器中的查詢內容, 並返回執行結果

docker exec -t  容器ID ls -l /tmp/

6. 從容器內拷貝檔案到主機上

docker cp 容器ID:容器內路徑  目標主機地址

搜尋資料:https://www.bilibili.com/video/BV1og4y1q7M4?p=12&spm_id_from=pageDriver