009.Docker Compose部署及基礎使用

一 Docker Compose概述

Compose是一個用於定義和運行多容器Docker應用程序的工具。使用Compose,您能夠使用YAML文件來配置應用程序的服務。而後,使用單個命令,您能夠從配置中建立並啓動全部服務。
Compose適用於全部環境:生產,登臺,開發,測試以及CI工做流程。
使用Compose基本上是一個三步過程:
  1. 在Dockerfile中定義您的應用程序環境,以即可以在任何地方進行再生產。
  2. 定義構成應用程序的服務,docker-compose.yml 以便它們能夠在隔離環境中一塊兒運行。
  3. 運行docker-compose up和Compose start並運行整個應用程序。
一個docker-compose.yml格式示例以下::
  1 version: '3'
  2 services:
  3   web:
  4     build: .
  5     ports:
  6     - "5000:5000"
  7     volumes:
  8     - .:/code
  9     - logvolume01:/var/log
 10     links:
 11     - redis
 12   redis:
 13     image: redis
 14 volumes:
 15   logvolume01: {}
Compose具備管理應用程序整個生命週期的命令:
  • 啓動,中止和重建服務
  • 查看正在運行的服務的狀態
  • 流式傳輸運行服務的日誌輸出
  • 在服務上運行一次性命令

二 Docker Compose安裝

2.1 二進制下載安裝

  1 root@docker01:~# sudo curl -L "https://github.com/docker/compose/releases/download/1.22.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
  2 root@docker01:~# sudo chmod +x /usr/local/bin/docker-compose
 

2.2 pip安裝(推薦)

  1 root@docker01:~# apt-get -y install python
  2 root@docker01:~# curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py
  3 root@docker01:~# python get-pip.py			#安裝PIP
  4 root@docker01:~# pip install docker-compose		#安裝docker compose
  5 root@docker01:~# docker-compose version		#驗證安裝
 

三 Docker Compose示例

3.1 構建應用程序

  1 root@docker01:~# mkdir composetest			#建立Docker Compose目錄
  2 root@docker01:~# cd composetest/
  3 root@docker01:~/composetest# vi app.py
 
提示:使用Python構建一個簡單應用,具體應用內容參考官方示例便可。
https://docs.docker.com/compose/gettingstarted/#step-1-setup

3.2 建立Dockerfile

  1 root@docker01:~/composetest# vi Dockerfile		#使用Dockerfile構建鏡像
  2 FROM python:3.4-alpine
  3 RUN mkdir /root/.pip				#建立pip源配置目錄
  4 ADD pip.conf /root/.pip/pip.conf			#將國內pip源添加至須要構建的鏡像中
  5 ADD . /code
  6 WORKDIR /code
  7 RUN pip install -r requirements.txt			#根據文件列表使用pip安裝
  8 CMD ["python", "app.py"]
 
提示:以上Dockerfile相關命令參考《004.docker鏡像管理》。
  1 root@docker01:~/composetest# vi requirements.txt	#建立安裝軟件列表文件
  2 flask
  3 redis
  4 root@docker01:~/composetest# vi pip.conf		#建立基於國內pip源的文件
  5 [global]
  6 index-url = https://mirrors.aliyun.com/pypi/simple/
  7 [install]
  8 trusted-host=mirrors.aliyun.com
 
Dockerfile解釋:
  • 從Python 3.4映像開始構建映像。
  • 建立pip配置目錄。
  • 將國內pip源配置文件添加到/root/.pip/映像中的路徑中。
  • 將當前目錄添加.到/code映像中的路徑中。
  • 將工做目錄設置爲/code。
  • 安裝Python相關包。
  • 將容器的默認命令設置爲python app.py。

3.3 使用Docker Compose構建服務

  1 root@docker01:~/composetest# vi docker-compose.yml
  2 version: '3'
  3 services:
  4   web:
  5     build: .
  6     ports:
  7      - "5000:5000"
  8   redis:
  9     image: "redis:alpine"
 
Docker Compose解釋:
此Compose文件定義了兩個服務,web和redis。
web服務:
  • 使用從Dockerfile當前目錄中構建的圖像。
  • 將容器上的公開端口5000轉發到主機上的端口5000。即便用Flask Web服務器的默認端口5000。
redis服務:
使用從Docker Hub拉取的公共Redis映像。
  1 root@docker01:~/composetest# docker-compose up -d		#開始構建

四 驗證確認

瀏覽器訪問:http://172.24.8.111:5000/
81_thumb1
  1 root@docker01:~/composetest# docker-compose ps
  2 root@docker01:~/composetest# docker ps
 
82_thumb1
  1 root@docker01:~/composetest# docker image ls
83_thumb1
提示:
使用Docker Compose構建的容器名稱規則爲:【構建時所在目錄】_【yml構建文件定義服務名】_【容器啓動序號】。
使用Docker Compose構建的鏡像名稱規則爲:【構建時所在目錄】_【yml構建文件定義服務名】,其tag爲latest。

五 掛載卷構建

  1 root@docker01:~/composetest# vi docker-compose.yml
  2 version: '3'
  3 services:
  4   web:
  5     build: .
  6     ports:
  7      - "5000:5000"
  8     volumes:
  9      - .:/code
 10   redis:
 11     image: "redis:alpine"
 12 root@docker01:~/composetest# docker-compose up -d		#再次構建
 13 root@docker01:~/composetest# vi app.py
 14 ……
 15 return 'Hello Docker! I have been seen {} times.\n'.format(count)
 16 ……
 
瀏覽器訪問:http://172.24.8.111:5000/
84_thumb1
提示:掛載本地卷至容器後,可快速修改本地文件,從而達到動態修改容器而無需重建image做用。

六 Docker Compose其餘經常使用命令

  1 docker-compose up -d:在後臺運行服務;
  2 docker-compose ps:查看當前正在運行的容器;
  3 docker-compose run:運行一次性命令,如docker-compose run web env。
 
85_thumb1
  1 docker-compose stop:中止服務,如docker-compose stop web
提示:docker-compose以yaml中服務名做爲參數,而非容器名稱或ID。
  1 docker-compose down --volumes:徹底刪除容器同時刪除容器使用的數據卷。
提示:更多Docker Compose命令參考《附004.Docker Compose命令詳解》。
相關文章
相關標籤/搜索