docker 客戶(hù)端非常簡(jiǎn)單 ,我們可以直接輸入 docker 命令來(lái)查看到 Docker 客戶(hù)端的所有命令選項(xiàng)。
cainiaoplus@cainiaoplus:~# docker
可以通過(guò)命令 docker command --help 更深入的了解指定的 Docker 命令使用方法。
例如我們要查看 docker stats 指令的具體使用方法:
cainiaoplus@cainiaoplus:~# docker stats --help
如果我們本地沒(méi)有 ubuntu 鏡像,我們可以使用 docker pull 命令來(lái)載入 ubuntu 鏡像:
$ docker pull ubuntu
以下命令使用 ubuntu 鏡像啟動(dòng)一個(gè)容器,參數(shù)為以命令行模式進(jìn)入該容器:
$ docker run -it ubuntu /bin/bash
參數(shù)說(shuō)明:
-i: 交互式操作。
-t: 終端。
ubuntu: ubuntu 鏡像。
/bin/bash:放在鏡像名后的是命令,這里我們希望有個(gè)交互式 Shell,因此用的是 /bin/bash。
要退出終端,直接輸入 exit:
root@ed09e4490c57:/# exit
查看所有的容器命令如下:
$ docker ps -a
點(diǎn)擊圖片查看大圖:
使用 docker start 啟動(dòng)一個(gè)已停止的容器:
$ docker start b750bbbcfd88
在大部分的場(chǎng)景下,我們希望 docker 的服務(wù)是在后臺(tái)運(yùn)行的,我們可以過(guò) -d 指定容器的運(yùn)行模式。
$ docker run -itd --name ubuntu-test ubuntu /bin/bash
點(diǎn)擊圖片查看大圖:
注:加了 -d 參數(shù)默認(rèn)不會(huì)進(jìn)入容器,想要進(jìn)入容器需要使用指令 docker exec(下面會(huì)介紹到)。
停止容器的命令如下:
$ docker stop <容器 ID>
停止的容器可以通過(guò) docker restart 重啟:
$ docker restart <容器 ID>
在使用 -d 參數(shù)時(shí),容器啟動(dòng)后會(huì)進(jìn)入后臺(tái)。此時(shí)想要進(jìn)入容器,可以通過(guò)以下指令進(jìn)入:
docker attach
docker exec:推薦大家使用 docker exec 命令,因?yàn)榇送顺鋈萜鹘K端,不會(huì)導(dǎo)致容器的停止。
attach 命令
下面演示了使用 docker attach 命令。
$ docker attach 1e560fca3906
注意: 如果從這個(gè)容器退出,會(huì)導(dǎo)致容器的停止。
exec 命令
下面演示了使用 docker exec 命令。
docker exec -it 243c32535da7 /bin/bash
注意: 如果從這個(gè)容器退出,容器不會(huì)停止,這就是為什么推薦大家使用 docker exec 的原因。
更多參數(shù)說(shuō)明請(qǐng)使用 docker exec --help 命令查看。
導(dǎo)出容器
如果要導(dǎo)出本地某個(gè)容器,可以使用 docker export 命令。
$ docker export 1e560fca3906 > ubuntu.tar
導(dǎo)出容器 1e560fca3906 快照到本地文件 ubuntu.tar。
這樣將導(dǎo)出容器快照到本地文件。
導(dǎo)入容器快照
可以使用 docker import 從容器快照文件中再導(dǎo)入為鏡像,以下示例將快照文件 ubuntu.tar 導(dǎo)入到鏡像 test/ubuntu:v1:
$ cat docker/ubuntu.tar | docker import - test/ubuntu:v1
此外,也可以通過(guò)指定 URL 或者某個(gè)目錄來(lái)導(dǎo)入,例如:
$ docker import http://example.com/exampleimage.tgz example/imagerepo
刪除容器使用 docker rm 命令:
$ docker rm -f 1e560fca3906
下面的命令可以清理掉所有處于終止?fàn)顟B(tài)的容器。
$ docker container prune
前面我們運(yùn)行的容器并沒(méi)有一些什么特別的用處。
接下來(lái)讓我們嘗試使用 docker 構(gòu)建一個(gè) web 應(yīng)用程序。
我們將在docker容器中運(yùn)行一個(gè) Python Flask 應(yīng)用來(lái)運(yùn)行一個(gè)web應(yīng)用。
cainiaoplus@cainiaoplus:~# docker pull training/webapp # 載入鏡像 cainiaoplus@cainiaoplus:~# docker run -d -P training/webapp python app.py
參數(shù)說(shuō)明:
-d:讓容器在后臺(tái)運(yùn)行。
-P:將容器內(nèi)部使用的網(wǎng)絡(luò)端口隨機(jī)映射到我們使用的主機(jī)上。
使用 docker ps 來(lái)查看我們正在運(yùn)行的容器:
cainiaoplus@cainiaoplus:~# docker ps CONTAINER ID IMAGE COMMAND ... PORTS d3d5e39ed9d3 training/webapp "python app.py" ... 0.0.0.0:32769->5000/tcp
這里多了端口信息。
PORTS 0.0.0.0:32769->5000/tcp
Docker 開(kāi)放了 5000 端口(默認(rèn) Python Flask 端口)映射到主機(jī)端口 32769 上。
這時(shí)我們可以通過(guò)瀏覽器訪(fǎng)問(wèn)WEB應(yīng)用
我們也可以通過(guò) -p 參數(shù)來(lái)設(shè)置不一樣的端口:
cainiaoplus@cainiaoplus:~$ docker run -d -p 5000:5000 training/webapp python app.py
docker ps查看正在運(yùn)行的容器
cainiaoplus@cainiaoplus:~# docker ps CONTAINER ID IMAGE PORTS NAMES bf08b7f2cd89 training/webapp ... 0.0.0.0:5000->5000/tcp wizardly_chandrasekhar d3d5e39ed9d3 training/webapp ... 0.0.0.0:32769->5000/tcp xenodochial_hoov
容器內(nèi)部的 5000 端口映射到我們本地主機(jī)的 5000 端口上。
通過(guò) docker ps 命令可以查看到容器的端口映射,docker 還提供了另一個(gè)快捷方式 docker port,使用 docker port 可以查看指定 (ID 或者名字)容器的某個(gè)確定端口映射到宿主機(jī)的端口號(hào)。
上面我們創(chuàng)建的 web 應(yīng)用容器 ID 為 bf08b7f2cd89 名字為 wizardly_chandrasekhar。
我可以使用 docker port bf08b7f2cd89 或 docker port wizardly_chandrasekhar 來(lái)查看容器端口的映射情況。
cainiaoplus@cainiaoplus:~$ docker port bf08b7f2cd89 5000/tcp -> 0.0.0.0:5000
cainiaoplus@cainiaoplus:~$ docker port wizardly_chandrasekhar 5000/tcp -> 0.0.0.0:5000
docker logs [ID或者名字] 可以查看容器內(nèi)部的標(biāo)準(zhǔn)輸出。
cainiaoplus@cainiaoplus:~$ docker logs -f bf08b7f2cd89 * Running on http://0.0.0.0:5000/ (Press CTRL+C to quit) 192.168.239.1 - - [09/May/2016 16:30:37] "GET / HTTP/1.1" 200 - 192.168.239.1 - - [09/May/2016 16:30:37] "GET /favicon.ico HTTP/1.1" 404 -
-f: 讓 docker logs 像使用 tail -f 一樣來(lái)輸出容器內(nèi)部的標(biāo)準(zhǔn)輸出。
從上面,我們可以看到應(yīng)用程序使用的是 5000 端口并且能夠查看到應(yīng)用程序的訪(fǎng)問(wèn)日志。
我們還可以使用 docker top 來(lái)查看容器內(nèi)部運(yùn)行的進(jìn)程
cainiaoplus@cainiaoplus:~$ docker top wizardly_chandrasekhar UID PID PPID ... TIME CMD root 23245 23228 ... 00:00:00 python app.py
使用 docker inspect 來(lái)查看 Docker 的底層信息。它會(huì)返回一個(gè) JSON 文件記錄著 Docker 容器的配置和狀態(tài)信息。
cainiaoplus@cainiaoplus:~$ docker inspect wizardly_chandrasekhar [ { "Id": "bf08b7f2cd897b5964943134aa6d373e355c286db9b9885b1f60b6e8f82b2b85", "Created": "2018-09-17T01:41:26.174228707Z", "Path": "python", "Args": [ "app.py" ], "State": { "Status": "running", "Running": true, "Paused": false, "Restarting": false, "OOMKilled": false, "Dead": false, "Pid": 23245, "ExitCode": 0, "Error": "", "StartedAt": "2018-09-17T01:41:26.494185806Z", "FinishedAt": "0001-01-01T00:00:00Z" }, ......
cainiaoplus@cainiaoplus:~$ docker stop wizardly_chandrasekhar wizardly_chandrasekhar
已經(jīng)停止的容器,我們可以使用命令 docker start 來(lái)啟動(dòng)。
cainiaoplus@cainiaoplus:~$ docker start wizardly_chandrasekhar wizardly_chandrasekhar
docker ps -l 查詢(xún)最后一次創(chuàng)建的容器:
# docker ps -l CONTAINER ID IMAGE PORTS NAMES bf08b7f2cd89 training/webapp ... 0.0.0.0:5000->5000/tcp wizardly_chandrasekhar
正在運(yùn)行的容器,我們可以使用 docker restart 命令來(lái)重啟。
我們可以使用 docker rm 命令來(lái)刪除不需要的容器
cainiaoplus@cainiaoplus:~$ docker rm wizardly_chandrasekhar wizardly_chandrasekhar
刪除容器時(shí),容器必須是停止?fàn)顟B(tài),否則會(huì)報(bào)如下錯(cuò)誤
cainiaoplus@cainiaoplus:~$ docker rm wizardly_chandrasekhar Error response from daemon: You cannot remove a running container bf08b7f2cd897b5964943134aa6d373e355c286db9b9885b1f60b6e8f82b2b85. Stop the container before attempting removal or force remove