濮阳杆衣贸易有限公司

主頁 > 知識庫 > Docker 容器編排利器Compose(起步篇)

Docker 容器編排利器Compose(起步篇)

熱門標簽:上海電銷卡外呼系統(tǒng)廠家 地圖標注員怎么去做 百度地圖標注備注 好看的地圖標注圖標下載 德州外呼系統(tǒng)排名 威海人工智能電銷機器人系統(tǒng) 機器人電銷有什么用 福州外呼系統(tǒng)中間件 貴州全自動外呼系統(tǒng)廠家

一個大型的Docker組成的微服務應用中,容器的數(shù)量是非常龐大的,如果依賴傳統(tǒng)的人工配置方式進行維護,對于開發(fā)和運維來說簡直就是噩夢。Compose的出現(xiàn)正是為了解決這個問題。

Compose簡介

Compose的前身是Fig,F(xiàn)ig被Docker收購之后正式更名為Compose,Compose向下兼容Fig。Compose是一個用于定義和運行多容器Docker應用的工具,只需要一個Compose的配置文件和一個簡單的命令就可以創(chuàng)建并運行應用所需的所有容器。在配置文件中,所有容器通過services來定義,并使用docker-compose命令啟動或停止容器以及所有依賴容器。

安裝Compose

Compose的安裝方式有多種,這里推薦使用curl命令安裝,在安裝之前,要確保你的機器上已經安裝了Docker,可以運行sudo docker version命令來確認是否已安裝了Docker。截至目前,Compose的最新發(fā)布版為1.11.2,下面演示在一臺已經安裝好Docker的Linux主機上安裝Compose。

安裝很簡單,只需要執(zhí)行下面的命令即可:

復制代碼 代碼如下:
sudo curl -L "https://github.com/docker/compose/releases/download/1.11.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

等待安裝完畢后,執(zhí)行下面的命令,為docker-compose添加可執(zhí)行權限:

chmod +x /usr/local/bin/docker-compose

輸入docker-compose --version命令可以查看安裝結果。

除了這種安裝方式之外,還可以通過Python的pip命令安裝或將Compose安裝成Docker容器,詳情請參見https://docs.docker.com/compose/install/#install-as-a-container。

如果要卸載Compose,可以執(zhí)行sudo rm /usr/local/bin/docker-compose命令。

Compose入門

下面我們通過一個簡單的例子演示Compose的使用步驟,使用Python構建一個Web應用,該應用使用Flask框架,并在Redis中維護一個命中計數(shù)(即使你不熟悉Python也沒有關系,你甚至不需要安裝Python和Redis,我們會從容器中獲取這些依賴環(huán)境)。

創(chuàng)建工程

首先需要一個文件夾作為項目文件夾:

mkdir composetest
cd composetest

在項目文件夾下創(chuàng)建一個app.py的文件,并將下面的代碼拷貝并粘貼到該文件中:

from flask import Flask
from redis import Redis

app = Flask(__name__)
redis = Redis(host='redis', port=6379)

@app.route('/')
def hello():
  count = redis.incr('hits')
  return 'Hello World! I have been seen {} times.\n'.format(count)

if __name__ == "__main__":
  app.run(host="0.0.0.0", debug=True)

在項目文件夾下創(chuàng)建一個requirements.txt的文件,并將下面的代碼拷貝并粘貼到該文件中:

flask
redis

到此,我們已經完成了新建項目,編碼,添加依賴等工作。

創(chuàng)建Dockerfile

下面我們創(chuàng)建一個Dockerfile文件用于構建Docker鏡像,該鏡像包含了運行該Web應用的所有依賴,包括Python運行環(huán)境。

在項目文件夾下創(chuàng)建一個Dockerfile文件,并將下面的內容拷貝并粘貼到該文件中:

FROM python:3.4-alpine
ADD . /code
WORKDIR /code
RUN pip install -r requirements.txt
CMD ["python", "app.py"]

大概解釋一下這個配置文件:

  1. 使用python-3.4-alpine作為基礎鏡像
  2. 將當前目錄添加到鏡像中/code目錄下
  3. 將/code設置為工作目錄
  4. 安裝Python依賴
  5. 設置默認執(zhí)行命令

在Compose文件中定義services

在項目文件夾下創(chuàng)建一個docker-compose.yml文件,并將下面的內容拷貝并粘貼到該文件中:

version: '2'
services:
 web:
  build: .
  ports:
   - "5000:5000"
  volumes:
   - .:/code
 redis:
  image: "redis:alpine"

該配置文件中包含兩個services,即web和redis。web會使用當前目錄中的Dockerfile文件構建鏡像,并將容器的5000端口暴露給主機,然后將項目文件夾掛載到容器中的/code目錄下;redis使用官方發(fā)布的鏡像構建。

構建并運行

執(zhí)行下面的命令構建并運行容器:

sudo docker-compose up

容器構建完成并啟動后,可以在瀏覽器中輸入http://localhost:5000查看結果。頁面會打印“Hello World! I have been seen 1 times.”,刷新頁面后,計數(shù)會累加變成2。

更新應用

由于項目文件夾掛載到了容器中,所以我們可以直接修改項目文件夾的應用,修改的結果立即反應到容器中,而不用重新啟動容器。將app.py文件中的hello方法中的返回值修改成如下:

return 'Hello from Docker! I have been seen {} times.\n'.format(count)

保存后刷新瀏覽器,發(fā)現(xiàn)打印結果已經更新。

Compose的其他命令

上面提到的Componse使用命令構建并啟動容器,是以前臺的方式啟動的,如果希望以后臺啟動,可以添加參數(shù)-d,比如下面這樣:

sudo docker-compose up -d

docker-compose ps命令可以查看正在運行的容器:

liuwei@liuwei-Ubuntu:~$ sudo docker-compose ps
Name           Command        State      Ports
-------------------------------------------------------------------------------------
composetest_redis_1  docker-entrypoint.sh redis ...  Up   6379/tcp
composetest_web_1   python app.py          Up   0.0.0.0:5000->5000/tcp

如果使用sudo docker-compose up -d命令以后臺方式啟動,可以用docker-compose stop命令停止。docker-compose down --volumes命令可以停止容器并將其刪除, --volumns表示同時刪除redis數(shù)據(jù)文件目錄。

有關Compose的更多命令,可以通過sudo docker-compose --help查看。

以上就是Compose的一個基本使用過程,可以發(fā)現(xiàn),Compose將docker run命令整合到了一個docker-compose.yml配置文件中,對于大型Docker集群的管理是很方便的,例可以將多個service組合成更復雜的service組,為每個service指定不同的Dockerfile,然后把它們link在一起。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:白城 南陽 南陽 葫蘆島 撫州 泉州 岳陽 邵陽

巨人網絡通訊聲明:本文標題《Docker 容器編排利器Compose(起步篇)》,本文關鍵詞  Docker,容器,編排,利器,Compose,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Docker 容器編排利器Compose(起步篇)》相關的同類信息!
  • 本頁收集關于Docker 容器編排利器Compose(起步篇)的相關信息資訊供網民參考!
  • 推薦文章
    兖州市| 呼伦贝尔市| 芦溪县| 贵州省| 武清区| 大同市| 澜沧| 昂仁县| 肃南| 大兴区| 珠海市| 卢氏县| 涞源县| 防城港市| 曲阜市| 筠连县| 达州市| 文安县| 三门峡市| 宁安市| 眉山市| 灵璧县| 阳原县| 桐柏县| 固始县| 福建省| 千阳县| 当雄县| 栖霞市| 依安县| 通榆县| 无锡市| 肥乡县| 江山市| 平邑县| 天等县| 腾冲县| 潼关县| 锡林郭勒盟| 通河县| 临安市|