docker compose的簡單使用

筆記內容:docker compose的簡單使用
筆記日期:2018-02-08html

  • 25.17 安裝docker compose
  • 25.18 docker compose示例

安裝docker compose

docker compose能夠方便咱們快捷高效地管理容器的啓動、中止以及重啓等操做,和批量管理容器,它相似於linux下的shell腳本,基於yaml語法,在該文件裏咱們能夠描述應用的架構,好比用什麼鏡像、數據卷、網絡模式、監聽端口等信息。咱們能夠在一個compose文件中定義一個多容器的應用(好比jumpserver),而後經過該compose來啓動這個應用。linux

安裝compose的方法以下,下載docker-compose而後放到/usr/local/bin/目錄下,再更改一下權限便可:nginx

[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,能夠到github上找最新版:git

https://github.com/docker/compose/releasesgithub

docker compose的安裝就這麼簡單,安裝完後,咱們來查看一下版本信息:web

[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


docker compose示例

以上咱們已經安裝好了docker compose ,下面用一個簡單的示例演示一下如何使用docker compose,編輯.yml文件,內容以下:shell

[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

編輯完以後就能夠啓動了:vim

[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看一下是否已啓動成功:
Alt textcentos

若是你沒有加 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狀態:
Alt text

因此要加上 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

相關文章
相關標籤/搜索