docker compose的簡單使用
筆記日期:2018-02-08
- 25.17 安裝docker compose
- 25.18 docker compose示例
安裝docker compose
docker compose可以方便我們快捷高效地管理容器的啟動、停止以及重啟等操作,和批量管理容器,它類似於linux下的shell腳本,基於yaml語法,在該文件裏我們可以描述應用的架構,比如用什麽鏡像、數據卷、網絡模式、監聽端口等信息。我們可以在一個compose文件中定義一個多容器的應用(比如jumpserver),然後通過該compose來啟動這個應用。
安裝compose的方法如下,下載docker-compose然後放到/usr/local/bin/目錄下,再更改一下權限即可:
[root@server ~]# curl -L https://github.com/docker/compose/releases/download/1.17.0-rc1/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
[root@server ~]# chmod 755 !$ # 指定權限
chmod 755 /usr/local/bin/docker-compose
[root@server ~]#
docker compose的安裝就這麽簡單,安裝完後,我們來查看一下版本信息:
[root@server ~]# docker-compose version docker-compose version 1.17.0-rc1, build a0f95af docker-py version: 2.5.1 CPython version: 2.7.13 OpenSSL version: OpenSSL 1.0.1t 3 May 2016 [root@server ~]#
說明:Compose區分Version 1和Version 2(Compose 1.6.0+,Docker Engine 1.10.0+)。Version 2支持更多的指令。Version 1沒有聲明版本默認是"version 1"。Version 1將來會被棄用。
docker compose示例
以上我們已經安裝好了docker compose ,下面用一個簡單的示例演示一下如何使用docker compose,編輯.yml文件,內容如下:
[root@server ~]# vim docker-compose.yml version: "2" # 使用Version 2 services: # 包含需要操作的容器 app1: # 容器的名稱 image: centos_nginx # 指定基於哪個鏡像 ports: # 指定映射的端口 - "8080:80" networks: # 指定使用哪個網絡模式 - "net1" volumes: # 指定掛載的的目錄 - /data/:/data app2: image: test_centos networks: - "net2" volumes: - /data/:/data1 entrypoint: tail -f /etc/passwd # 這一句是為了讓這個容器不會被關閉 networks: net1: driver: bridge net2: driver: bridge
編輯完之後就可以啟動了:
[root@server ~]# docker-compose up -d # -d是丟到後臺運行
Creating network "root_net2" with driver "bridge"
Creating network "root_net1" with driver "bridge"
Creating root_app2_1 ...
Creating root_app1_1 ...
Creating root_app2_1
Creating root_app1_1 ... done
[root@server ~]#
然後docker ps看一下是否已啟動成功:
如果你沒有加 entrypoint: tail -f /etc/passwd
這樣的語句的話,那麽app2被啟動之後就會馬上關閉了,所以加這一句沒別的作用,就是為了不被馬上關閉。不信的話,我現在刪除掉那兩個容器,然後再把 docker-compose.yml 文件裏的那句命令給註釋掉,再啟動:
[root@server ~]# docker rm -f df21c6ec7
df21c6ec7
[root@server ~]# docker rm -f c2dda49
c2dda49
[root@server ~]# vim docker-compose.yml
[root@server ~]# docker-compose up -d
Creating root_app2_1 ...
Creating root_app1_1 ...
Creating root_app2_1
Creating root_app1_1 ... done
[root@server ~]#
如上,可以看到,啟動是成功的,但是我dicker ps -a查看卻只有app1是在啟動狀態,而app2是在Exited狀態:
所以要加上 entrypoint: tail -f /etc/passwd
的原因就在這,這個語句的唯一作用就是防止容器被關閉,這是docker的一個特性,說實話我也不知道為嘛要加這樣的一句話,但是不加的話末尾啟動的那個容器就會被關閉,不過不一定非要寫 tail -f /etc/passwd
,也可以是其他可正常執行的命令。
docker-compose --help
可以查看該命令的文檔,下面介紹幾個常用的命令參數:
停止已有的容器:
[root@server ~]# docker-compose stop
Stopping root_app1_1 ... done
Stopping root_app2_1 ... done
[root@server ~]#
啟動已有的容器:
[root@server ~]# docker-compose start
Starting app2 ... done
Starting app1 ... done
[root@server ~]#
查看容器的狀態:
[root@server ~]# docker-compose ps
Name Command State Ports
---------------------------------------------------------------
root_app1_1 /bin/sh -c /usr/local/ngin ... Exit 137
root_app2_1 tail -f /etc/passwd Exit 137
[root@server ~]#
刪除容器:
[root@server ~]# docker-compose rm -f
Going to remove root_app1_1, root_app2_1
Removing root_app1_1 ... done
Removing root_app2_1 ... done
[root@server ~]#
停止並刪除運行中的容器:
[root@server ~]# docker-compose down
Stopping root_app1_1 ... done
Stopping root_app2_1 ... done
Removing root_app1_1 ... done
Removing root_app2_1 ... done
Removing network root_net2
Removing network root_net1
[root@server ~]# docker-compose ps
Name Command State Ports
------------------------------
[root@server ~]#
關於docker-compose語法的參考文檔:
http://www.web3.xin/index/article/182.html
docker compose的簡單使用