Docker 編排工具 Fig 介紹

4 贊 回覆發表於2015-01-07

【編者的話】Fig是一個基於Docker的用於快速搭建開發環境的工具,目前Fig團隊已經加入Docker公司。Fig通過一個配置檔案來管理多個 Docker容器,非常適合組合使用多個容器進行開發的場景。Fig可以和Docker一起來構建基於Docker的複雜應用。本文詳細介紹了Fig的安裝以及使用。

什麼是編排?

編排(譯者注:Orchestration,翻譯為編排)是指同時管理多個容器的行為。當你剛開始玩Docker 的時候,你只需要操作一個容器。緊接著你學習了網路並得知把所有程式都放入同一個容器中並不合適,然後不知不覺你就發現自己已經建立了多容器的基礎架構。 你第一次嘗試可能不會感到複雜,但是當使用兩個或者三個容器的時候,你就會覺得很麻煩。手動連線容器、管理卷,很快你就亂了,應該有更好更實用的工具來做 這件事。

Fig簡介

這個更實用的工具稱為Fig。Fig是Orchard的一個產品並很快成為自動化Docker容器編排一個事實標準,目前Fig已經被Docker公司收購併成為官方支援的解決方案。

安裝Fig

Fig是一個Python Package,你可以使用以下命令來安裝:

$ sudo pip install -U fig

就這麼簡單。如果不能工作,可以從Fig的官方文件中瞭解更多資訊。

使用Fig

使用Fig來編排一個基礎設施,你首先需要在YAML配置檔案中描述它。描述語法很簡單,和Docker有點類似。
下面是Pagekit CMS的Fig配置示例:

web:
image: ubermuda/pagekit
ports:
    - 80
links:
    - db:pagekit_db_1
volumes_from:
    - data
db:
image: orchardup/mysql
environment:
    MYSQL_ROOT_PASSWORD: changethis
    MYSQL_DATABASE: pagekit
data:
image: busybox
command: /bin/true
volumes:
    - /pagekit/storage
    - /pagekit/app/cache

這個配置檔案定義了三個不同的容器。

web容器是面向web方面的容器,它基於ubermuda/pagekit映象構建,你可以從GitHub上獲取ubermuda/pagekit的原始碼,web容器會暴露80埠(通過ports引數),使用別名pagekit_db_1(links)連線到db容器,並且data容器的卷(volumes)也會被掛載到web容器。

從db容器中我們能看到在容器中定義環境變數是多麼簡單:只要使用environment配置即可。在示例中,我們在配置檔案中定義了所有的值,但你也可以省略這些值,這樣容器會從它的宿主機中獲取。

db:
environment:
    MYSQL_ROOT_PASSWORD

所述的MYSQL_ROOT_PASSWORD環境變數被來自主機的同名環境變數填充。

最後,data容器通過volumes引數定義了即將使用的所有目錄作為共享卷目錄。

配置檔案寫完後,你只需要一個fig up命令即可啟動你的基礎設施。

$ fig up
Creating dockerpagekit_db_1...
...
Creating dockerpagekit_data_1...
Creating dockerpagekit_web_1...
...
Attaching to dockerpagekit_db_1, dockerpagekit_web_1
...
db_1  | 141110  4:14:02 [Note] /usr/sbin/mysqld: ready for connections.
db_1  | Version: '5.5.38-0ubuntu0.12.04.1-log'  socket: '/var/run/mysqld/mysqld.sock'  port: 3306  (Ubuntu)
...
web_1 | 2014-11-10 04:15:20,750 INFO success: nginx entered RUNNING state, process has stayed up for > than 1 seconds (startsecs)
web_1 | 2014-11-10 04:15:20,750 INFO success: php5-fpm entered RUNNING state, process has stayed up for > than 1 seconds (startsecs)

完整的啟動日誌有點太長了,所以我只擷取了一部分。正如你所看到的,Fig建立了三個容器,dockerpagekit_db_1可以連線到dockerpagekit_web_1,正是我們想要的。

你可能還注意到有一個資料容器沒有日誌線,那是因為 /bin/true 命令無法正常輸出。

現在你可以在另一個終端中執行docker ps命令來檢查一切是否執行正常,同時,可是使用瀏覽器來確認web容器是否正常啟動。(你首先需要確認對映埠,可以使用docker ps或docker port)。

說明

截至本文寫作之時,Fig不支援遠端編排,這意味著你只能在單臺主機上編排一個基礎設施。

相關文章