Docker Compose 命令詳解
一、docker-compose 命令對象與格式
二、命令選項
三、命令使用說明
-
build 構建(重新構建)項目中的服務容器
-
config 檢測 compose 文件的錯誤
-
up 啓動服務
-
down 停止容器
-
images 列出項目中所包含的鏡像
-
logs 查看服務容器的日誌
-
kill 發送 SIGKILL 信號來強制停止服務容器
-
port 查看某個容器端口所映射的公共端口
-
ps 列出項目中目前的所有容器
-
restart 重啓項目中的服務
-
rm 刪除所有停止狀態的服務容器
-
run 在指定服務上運行一個命令
-
scale 設置指定服務運行的容器個數
-
stop 停止處於運行狀態的容器
-
start 啓動被 stop 的服務容器
-
top 查看各個服務容器內運行的進程
-
pause 暫停一個服務容器
-
unpause 恢復處於暫停狀態中的服務
docker-compose 術語:
服務(service):一個應用容器,實際上可以運行多個相同鏡像的實例。
項目(project):由一組關聯的應用容器組成的一個完整業務單元。
一個項目可以由多個服務(容器)關聯而成,Compose 面向項目進行管理。
一、命令對象與格式
對於 Compose 來說,大部分命令的對象既可以是項目本身,也可以指定爲項目中的服務或者容器。如果沒有特別的說明,命令對象將是項目,這意味着項目中所有的服務都會受到命令影響。
docker-compose 命令的基本的使用格式是:
[root@centos01 ~]# docker-compose [-f <arg>...] [options] [COMMAND] [ARGS...]
二、命令選項
-f:指定使用的 compose 模板文件,默認爲當前目錄下的 docker-compose.yaml 文件,可以多次指定。
-p:指定項目的名稱,默認將使用所在目錄名稱作爲項目名。
–verbose:輸出更多調試信息。
-v:打印版本信息並退出。
三、命令使用說明
- build 構建(重新構建)項目中的服務容器
命令格式爲:
[root@centos01 ~]# docker-compose build [options] [SERVICE...]
服務容器一旦構建後,將會帶上一個標記名,例如對於 web 項目中的一個 db 容器,可能是 web_db。
可以隨時在項目目錄下運行 docker-compose build 來重新構建服務。
上述命令選項包括:
–force-rm:刪除構建過程中的臨時容器;
–no-cache:構建鏡像過程中不使用 cache(這會加長構建過程);
–pull:始終嘗試通過 pull 來獲取更新版本的鏡像;
- config 檢測 compose 文件的錯誤
驗證 Compose 文件格式是否正確,若正確則顯示配置,若格式錯誤顯示錯誤原因。
命令格式如下:
[root@centos01 ~]# docker-compose config
- up 啓動服務
格式爲:
[root@centos01 ~]# docker-compose up [options] [SERVICE...]
該命令十分強大,它將嘗試自動完成包括構建鏡像,(重新)創建服務,啓動服務,並關聯服務相關容器的一系列操作。
鏈接的服務都將會被自動啓動,除非已經處於運行狀態。
可以說,大部分時候都可以直接通過該命令來啓動一個項目。
默認情況,docker-compose up 啓動的容器都在前臺,控制檯將會同時打印所有容器的輸出信息,可以很方便進行調試。
當通過 Ctrl-C 停止命令時,所有容器將會停止。
如果使用 docker-compose up -d,將會在後臺啓動並運行所有的容器。一般推薦生產環境下使用該選項。
默認情況,如果服務容器已經存在,docker-compose up 將會嘗試停止容器,然後重新創建(保持使用 volumes-from 掛載的卷),以保證新啓動的服務匹配 docker-compose.yml 文件的最新內容。如果用戶不希望容器被停止並重新創建,可以使用 docker-compose up --no-recreate。這樣將只會啓動處於停止狀態的容器,而忽略已經運行的服務。如果用戶只想重新部署某個服務,可以使用 docker-compose up --no-deps -d <SERVICE_NAME> 來重新創建服務並後臺停止舊服務,啓動新服務,並不會影響到其所依賴的服務。
選項:
-d:在後臺運行服務容器;
–no-color:不使用顏色來區分不同的服務的控制檯輸出;
–no-deps:不啓動服務所鏈接的容器;
–force-recreate:強制重新創建容器,不能與 --no-recreate 同時使用;
–no-recreate:如果容器已經存在了,則不重新創建,不能與 --force-recreate 同時使用;
–no-build:不自動構建缺失的服務鏡像;
-t:停止容器時候的超時(默認爲 10 秒);
- down 停止容器
此命令將會停止 up 命令所啓動的容器,並移除網絡。
- images 列出項目中所包含的鏡像
[root@centos01 ~]# docker-compose images <!--列出項目中所包含的鏡像-->
[root@centos01 ~]# docker-compose -p tt images <!--若不是默認的項目名稱,則需要指定項目名稱-->
- logs 查看服務容器的日誌
格式爲:
[root@centos01 ~]# docker-compose logs [options] [SERVICE...]
默認情況下,docker-compose 將對不同的服務輸出使用不同的顏色來區分。可以通過 --no-color 來關閉顏色。
該命令在調試問題的時候十分有用。
[root@centos01 ~]# cat docker-compose.yml <!--compose文件如下-->
version: '3'
services:
web:
build: .
ports:
- "5001:5000"
redis:
image: "redis:alpine"
[root@centos01 ~]# docker-compose logs
<!--不加服務名稱則會顯示項目中所有服務的日誌,不同服務之間的日誌以不同的顏色區分-->
[root@centos01 ~]# docker-compose logs web
<!--也可以指定項目中的服務名稱,查看指定服務的日誌-->
[root@centos01 ~]# docker-compose logs redis <!--同上-->
- kill 發送 SIGKILL 信號來強制停止服務容器
格式爲:
[root@centos01 ~]# docker-compose kill [options] [SERVICE...]
支持通過 -s 參數來指定發送的信號,例如通過如下指令發送 SIGINT 信號。
[root@centos01 ~]# docker-compose kill -s SIGINT web <!--kill掉指定的服務-->
[root@centos01 ~]# docker-compose -p tt kill -s SIGINT web
<!--若不是默認的項目名稱,則需要-p指定項目名稱-->
- port 查看某個容器端口所映射的公共端口
格式爲:
[root@centos01 ~]# docker-compose port [options] SERVICE PRIVATE_PORT
選項:
–protocol=proto 指定端口協議,tcp(默認值)或者 udp;
–index=index 如果同一服務存在多個容器,指定命令對象容器的序號(默認爲 1);
[root@centos01 ~]# docker-compose port web 5000
0.0.0.0:5001
<!--上面的結果表示將web服務的5000端口映射到了宿主機的5001端口-->
- ps 列出項目中目前的所有容器
格式爲:
docker-compose ps [options] [SERVICE...]
舉個例子:
$ docker-compose ps -q web <!--查看某一個服務的ID-->
$ docker-compose ps <!--查看項目中所有服務的容器信息-->
選項:
-q:只打印容器的 ID 信息;
10、restart——重啓項目中的服務
格式爲:
[root@centos01 ~]# docker-compose restart [options] [SERVICE...]
選項:
-t, --timeout TIMEOUT 指定重啓前停止容器的超時(默認爲 10 秒)。
舉個例子:
[root@centos01 ~]# docker-compose restart <!--重啓當前項目中的所有服務-->
[root@centos01 ~]# docker-compose restart web <!--重啓當前項目中的web服務-->
- rm 刪除所有停止狀態的服務容器
格式爲 :
[root@centos01 ~]# docker-compose rm [options] [SERVICE...]
選項:
-f:不要求確認移除;
-s:在刪除前停止項目中的所有容器;
-v:刪除任何附加到容器的匿名卷;
- run 在指定服務上運行一個命令
格式爲:
[root@centos01 ~]# docker-compose run [options] [-p PORT...] [-e KEY=VAL...] SERVICE [COMMAND] [ARGS...]
例如:
[root@centos01 ~]# docker-compose run web ping www.baidu.com
上面的指令將啓動項目中的 web 服務容器,並執行 ping www.baidu.com 命令。
默認情況下,如果存在關聯,則所有關聯的服務將會自動被啓動,除非這些服務已經在運行中。
如果不希望自動啓動關聯的容器,可以使用 --no-deps 選項,例如:
[root@centos01 ~]# docker-compose run --no-deps web ping www.baidu.com
選項:
-d:後臺運行容器;
–name:爲容器指定一個名字;
–entrypoint :覆蓋默認的容器啓動指令;
-e KEY=VAL :設置環境變量值,可多次使用選項來設置多個環境變量;
-u:指定運行容器的用戶名或者 uid;
–no-deps :不自動啓動關聯的服務容器;
–rm:運行命令後自動刪除容器,d 模式下將忽略;
-p:映射容器端口到本地主機;
–service-ports:配置服務端口並映射到本地主機;
-T:不分配僞 tty,意味着依賴 tty 的指令將無法運行;
- scale 設置指定服務運行的容器個數
格式爲:
[root@centos01 ~]# docker-compose scale [options] [SERVICE=NUM...]
通過 service=num 的參數來設置數量。例如:
[root@centos01 ~]# docker-compose scale web=3 redis=2
將啓動 3 個容器運行 web 服務,2 個容器運行 redis 服務,但是需要注意的是,docker-compose 中定義 ports 字段時,就不可以指定映射到宿主機的端口了,否則只可以啓動一個。
一般的,當指定數目多於該服務當前實際運行容器,將新創建並啓動容器;反之,將停止容器。
選項:
-t:停止容器時候的超時(默認爲 10 秒);
- stop 停止處於運行狀態的容器
格式爲:
[root@centos01 ~]# docker-compose stop [options] [SERVICE...]
停止已經處於運行狀態的容器,但不刪除它。通過 docker-compose start 可以再次啓動這些容器。
舉個例子:
[root@centos01 ~]# docker-compose stop web <!--停止當前項目中的web服務-->
[root@centos01 ~]# docker-compose stop <!--停止當前項目中所有服務-->
選項:
-t:停止容器時候的超時(默認爲 10 秒);
- start 啓動被 stop 的服務容器
格式爲:
[root@centos01 ~]# docker-compose start [SERVICE...]
舉個例子:
[root@centos01 ~]# docker-compose start
- top 查看各個服務容器內運行的進程
[root@centos01 ~]# docker-compose top <!--查看項目中所有服務的進程-->
[root@centos01 ~]# docker-compose top web <!--查看項目中web服務的進程-->
- pause 暫停一個服務容器
格式爲:
[root@centos01 ~]# docker-compose pause [SERVICE...]
暫停一個服務容器。
舉個例子:
[root@centos01 ~]# docker-compose -p tt pause redis <!---p選項是指定項目名稱-->
<!--若是默認的項目名稱,則可以忽略-p選項-->
[root@centos01 ~]# docker-compose pause <!--暫停項目中的所有服務-->
- unpause 恢復處於暫停狀態中的服務
格式爲:
docker-compose unpause [SERVICE...]
舉個例子:
[root@centos01 ~]# docker-compose unpause
source: //blog.51cto.com/u_14156658/2498135
本文由 Readfog 進行 AMP 轉碼,版權歸原作者所有。
來源:https://mp.weixin.qq.com/s/k4HCBXzWVgRA8JDhR7ewYg