Docker Compose

可以使用一個Dockerfile模板文件來快速構(gòu)建一個自己的鏡像并運行為應(yīng)用容器弧岳,詳細(xì)請參考Dockerfile及鏡像的構(gòu)建。但是在平時工作的時候业踏,我們會碰到多個容器要互相配合來使用的情況禽炬,比如數(shù)據(jù)庫加上咱們Web應(yīng)用等等。這種情況下勤家,每次都要一個一個啟動容器設(shè)置命令變得麻煩起來瞎抛,所以Docker Compose誕生了。

簡介

Compose的作用是“定義和運行多個Docker容器的應(yīng)用”却紧。使用Compose桐臊,你可以在一個配置文件(yaml格式)中配置你應(yīng)用的服務(wù),然后使用一個命令晓殊,即可創(chuàng)建并啟動配置中引用的所有服務(wù)断凶。

Compose中兩個重要概念:

服務(wù) (service):一個應(yīng)用的容器,實際上可以包括若干運行相同鏡像的容器實例

項目 (project):由一組關(guān)聯(lián)的應(yīng)用容器組成的一個完整業(yè)務(wù)單元巫俺,在 docker-compose.yml文件中定義认烁。

安裝

Compose支持三平臺Windows、Mac介汹、Linux却嗡,安裝方式各有不同。我這里使用的是Linux系統(tǒng)嘹承,其他系統(tǒng)安裝方法可以參考官方文檔和開源GitHub鏈接:

Docker Compose官方文檔鏈接:https://docs.docker.com/compose

Docker Compose GitHub鏈接:https://github.com/docker/compose

Linux上有兩種安裝方法窗价,Compose項目是用Python寫的,可以使用Python-pip安裝叹卷,也可以通過GitHub下載二進(jìn)制文件進(jìn)行安裝撼港。

通過Python-pip安裝

1.安裝Python-pip

yum install -y epel-release

yum install -y python-pip

2.安裝docker-compose

pip install docker-compose

3.驗證是否安裝

docker-compose version

4.卸載

pip uninstall docker-compose

通過GitHub鏈接下載安裝

非ROOT用戶記得加sudo

1.通過GitHub獲取下載鏈接,以往版本地址:https://github.com/docker/compose/releases

curl -L "https://github.com/docker/compose/releases/download/1.23.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

2.給二進(jìn)制下載文件可執(zhí)行的權(quán)限

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

3.可能沒有啟動程序骤竹,設(shè)置軟連接帝牡,比如:

ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose

4.驗證是否安裝成功

docker-compose version

5.卸載

如果是二進(jìn)制包方式安裝的,刪除二進(jìn)制文件即可蒙揣。

rm /usr/local/bin/docker-compose

簡單實例

Compose的使用非常簡單靶溜,只需要編寫一個docker-compose.yml,然后使用docker-compose 命令操作即可懒震。docker-compose.yml描述了容器的配置罩息,而docker-compose 命令描述了對容器的操作。

1.我們使用一個微服務(wù)項目先來做一個簡單的例子挎狸,首先創(chuàng)建一個compose的工作目錄扣汪,然后創(chuàng)建一個eureka文件夾,里面放可執(zhí)行jar包和編寫一個Dockerfile文件锨匆,目錄結(jié)構(gòu)如下:

compose

????eureka

????????Dockerfile

????????eureka-server-2.0.2.RELEASE.jar

2.在compose目錄創(chuàng)建模板文件docker-compose.yml文件并寫入以下內(nèi)容:

version: '1'

services:

? eureka:

? ? build: ./eureka

? ? ports:

? ?????- 3000:3000

? ? expose:

? ????? - 3000

Docker Compose模板文件常用指令

image

指定鏡像名稱或者鏡像id崭别,如果該鏡像在本地不存在,Compose會嘗試pull下來恐锣。

示例:

image: java:8

build

指定Dockerfile文件的路徑茅主。可以是一個路徑土榴,例如:

build: ./dir

也可以是一個對象诀姚,用以指定Dockerfile和參數(shù),例如:

build:? context: ./dir? dockerfile: Dockerfile-alternate? args:? ? buildno: 1

command

覆蓋容器啟動后默認(rèn)執(zhí)行的命令玷禽。

示例:command: bundle exec thin -p 3000

也可以是一個list赫段,類似于Dockerfile總的CMD指令呀打,格式如下:

command: [bundle, exec, thin, -p, 3000]

links

鏈接到其他服務(wù)中的容器∨大希可以指定服務(wù)名稱和鏈接的別名使用SERVICE:ALIAS 的形式贬丛,或者只指定服務(wù)名稱,示例:

web:? links:? ? - db? ? - db:database? ? - redis

external_links

表示鏈接到docker-compose.yml外部的容器给涕,甚至并非Compose管理的容器豺憔,特別是對于那些提供共享容器或共同服務(wù)。格式跟links類似够庙,示例:

external_links:? - redis_1? - project_db_1:mysql? - project_db_1:postgresql

ports

暴露端口信息恭应。使用宿主端口:容器端口的格式,或者僅僅指定容器的端口(此時宿主機(jī)將會隨機(jī)指定端口)耘眨,類似于docker run -p 昼榛,示例:

ports:

????"3000"

????"3000-3005"

????"8000:8000"

????"9090-9091:8080-8081"

????"49100:22"

????"127.0.0.1:8001:8001"

????"127.0.0.1:5000-5010:5000-5010"

expose

暴露端口,只將端口暴露給連接的服務(wù)毅桃,而不暴露給宿主機(jī)褒纲,示例:

expose:? - "3000"? - "8000"

volumes

卷掛載路徑設(shè)置≡糠桑可以設(shè)置宿主機(jī)路徑 (HOST:CONTAINER) 或加上訪問模式 (HOST:CONTAINER:ro)莺掠。示例:

volumes:

Just specify a path and let the Engine create a volume

????/var/lib/mysql

Specify an absolute path mapping

????/opt/data:/var/lib/mysql

Path on the host, relative to the Compose file

????./cache:/tmp/cache

User-relative path

????~/configs:/etc/configs/:ro

Named volume

????datavolume:/var/lib/mysql

volumes_from

從另一個服務(wù)或者容器掛載卷《林妫可以指定只讀或者可讀寫彻秆,如果訪問模式?jīng)]有指定,則默認(rèn)是可讀寫结闸。示例:

volumes_from:

????service_name

????service_name:ro

????container:container_name

????container:container_name:rw

environment

設(shè)置環(huán)境變量唇兑。可以使用數(shù)組或者字典兩種方式桦锄。只有一個key的環(huán)境變量可以在運行Compose的機(jī)器上找到對應(yīng)的值扎附,這有助于加密的或者特殊主機(jī)的值。示例:

environment:? RACK_ENV: development? SHOW: 'true'? SESSION_SECRET:? environment:? - RACK_ENV=development? - SHOW=true? - SESSION_SECRET

env_file

從文件中獲取環(huán)境變量结耀,可以為單獨的文件路徑或列表留夜。如果通過 docker-compose -f FILE 指定了模板文件,則 env_file 中路徑會基于模板文件路徑图甜。如果有變量名稱與 environment 指令沖突碍粥,則以envirment 為準(zhǔn)。示例:

env_file: .env? env_file:? - ./common.env? - ./apps/web.env? - /opt/secrets.env

extends

繼承另一個服務(wù)黑毅,基于已有的服務(wù)進(jìn)行擴(kuò)展嚼摩。

net

設(shè)置網(wǎng)絡(luò)模式。示例:

net: "bridge"

net: "host"

net: "none"

net: "container:[service name or container name/id]"

dns

配置dns服務(wù)器≌砻妫可以是一個值愿卒,也可以是一個列表。示例:

dns: 8.8.8.8

dns:? - 8.8.8.8? - 9.9.9.9

dns_search

配置DNS的搜索域膊畴,可以是一個值掘猿,也可以是一個列表,示例:

dns_search: example.com?

dns_search:? - dc1.example.com? - dc2.example.com

其它

docker-compose.yml 還有很多其他命令唇跨,可以參考docker-compose.yml文件官方文檔:

https://docs.docker.com/compose/compose-file/

使用Docker Compose編排SpringCloud微服務(wù)

使用docker-compose一次性來編排三個微服務(wù):eureka服務(wù)(eureka-server-2.0.2.RELEASE.jar)、user服務(wù)(user-2.0.2.RELEASE.jar)衬衬、power服務(wù)(power-2.0.2.RELEASE.jar)

1.創(chuàng)建一個工作目錄和docker-compose模板文件

2.工作目錄下創(chuàng)建三個文件夾eureka买猖、user、power滋尉,并分別構(gòu)建好三個服務(wù)的鏡像文件

以eureka的Dockerfile為例:

# 基礎(chǔ)鏡像

FROM java:8

# 作者

MAINTAINER dyp

# 把可執(zhí)行jar包復(fù)制到基礎(chǔ)鏡像的根目錄下

ADD eureka-server-2.0.2.RELEASE.jar /eureka-server-2.0.2.RELEASE.jar

# 鏡像要暴露的端口玉控,如要使用端口,在執(zhí)行docker run命令時使用-p生效

EXPOSE 8080

# 在鏡像運行為容器后執(zhí)行的命令

ENTRYPOINT ["java","-jar","/eureka-server-2.0.2.RELEASE.jar"]

目錄文件結(jié)構(gòu):

compose

????docker-compose.yml

????eureka

????????Dockerfile

????????eureka-server-2.0.2.RELEASE.jar

????user

????????Dockerfile

????????user-2.0.2.RELEASE.jar

????power

????????Dockerfile

????????power-2.0.2.RELEASE.jar

3.編寫docker-compose模板文件:

version: '3.3'

services:

? eureka:

? ? image: eureka:v1

? ? ports:

? ? ???? - 8080:8080

? user:

? ? image: user:v1

? ? ports:

? ? ???? - 8081:8081

? power:

? ? image: power:v1

? ? ports:

? ? ???? - 8082:8082

4.啟動微服務(wù)狮惜,可以加上參數(shù)-d后臺啟動

docker-compose up -d

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末高诺,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子碾篡,更是在濱河造成了極大的恐慌虱而,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件开泽,死亡現(xiàn)場離奇詭異牡拇,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)穆律,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進(jìn)店門惠呼,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人峦耘,你說我怎么就攤上這事剔蹋。” “怎么了辅髓?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵泣崩,是天一觀的道長。 經(jīng)常有香客問我利朵,道長律想,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任绍弟,我火速辦了婚禮技即,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘樟遣。我一直安慰自己而叼,他們只是感情好身笤,可當(dāng)我...
    茶點故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著葵陵,像睡著了一般液荸。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上脱篙,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天娇钱,我揣著相機(jī)與錄音,去河邊找鬼绊困。 笑死文搂,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的秤朗。 我是一名探鬼主播煤蹭,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼取视!你這毒婦竟也來了硝皂?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤作谭,失蹤者是張志新(化名)和其女友劉穎稽物,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體丢早,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡姨裸,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了怨酝。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片傀缩。...
    茶點故事閱讀 38,747評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖农猬,靈堂內(nèi)的尸體忽然破棺而出赡艰,到底是詐尸還是另有隱情,我是刑警寧澤斤葱,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布慷垮,位于F島的核電站,受9級特大地震影響揍堕,放射性物質(zhì)發(fā)生泄漏料身。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一衩茸、第九天 我趴在偏房一處隱蔽的房頂上張望芹血。 院中可真熱鬧,春花似錦、人聲如沸幔烛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽饿悬。三九已至令蛉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間狡恬,已是汗流浹背珠叔。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留弟劲,地道東北人运杭。 一個月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像函卒,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子撇眯,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,658評論 2 350

推薦閱讀更多精彩內(nèi)容