您好,登錄后才能下訂單哦!
Docker中怎么使用Compose,很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
Compose項(xiàng)目是Docker官方的開(kāi)源項(xiàng)目,負(fù)責(zé)實(shí)現(xiàn)對(duì)Docker容器集群的快速編排
Compose定位是定義和運(yùn)行多個(gè)Docker容器的應(yīng)用,其前身是開(kāi)源項(xiàng)目Fig。
使用一個(gè)Dockerfile模板文件,可以很方便的定義一個(gè)單獨(dú)的應(yīng)用容器,然而在日常工作中,經(jīng)常會(huì)碰到需要多個(gè)容器相互配合來(lái)完成某項(xiàng)任務(wù)。例如要實(shí)現(xiàn)一個(gè)Web項(xiàng)目,除了Web服務(wù)器本身,通常還需要后端的數(shù)據(jù)庫(kù)服務(wù)容器,甚至負(fù)載均衡容器等。
Compose恰好滿足了這樣的需求。它可以通過(guò)一個(gè)單獨(dú)的docker-compose.yml模板文件來(lái)定義一組相關(guān)聯(lián)的應(yīng)用容器項(xiàng)目(project)。
Compose有兩個(gè)重要的概念:
服務(wù)(service):
一個(gè)應(yīng)用的容器,實(shí)際上可以包含若干個(gè)運(yùn)行相同鏡像的容器實(shí)例
項(xiàng)目(project):
由一組關(guān)聯(lián)的應(yīng)用容器組成一個(gè)完整的業(yè)務(wù)單元
Compose的默認(rèn)管理對(duì)象是項(xiàng)目,通過(guò)子命令對(duì)項(xiàng)目中的一組容器進(jìn)行便捷的生命周期管理。
Compose項(xiàng)目由Python編寫,實(shí)際上調(diào)用了Docker服務(wù)提供的API來(lái)對(duì)容器進(jìn)行管理
Compose可以通過(guò)Python的包管理工具pip進(jìn)行安裝,也可以直接下載編譯好的二進(jìn)制文件使用,甚至能夠直接在Docker容器中運(yùn)行。
Docker for Mac,Docker for Windows自帶docker-compose二進(jìn)制文件,安裝Docker之后可以直接使用,Linux系統(tǒng)需要單獨(dú)的二進(jìn)制文件或pip進(jìn)行安裝。
查看compose的安裝版本:
docker-compose --versino
Linux下的二進(jìn)制安裝:
curl -L https://github.com/docker/compose/releases/download/1.25.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
pip安裝:
sudo pip install -U docker-compose
應(yīng)用場(chǎng)景:一般Web網(wǎng)站都會(huì)依賴第三方的提供的服務(wù),如DB,cache,以compose編排運(yùn)行dubbo-admin為例
獲取源碼,從github上獲取dubbo-admin的master分支源碼
git clone -b master https://github.com/apache/incubator-dubbo-ops.git
修改admin中的application配置,把zookeeper地址改為zookeeper://zookeeper:2181
在項(xiàng)目根目錄下使用maven進(jìn)行打包
mvn clean package -Dmaven.test.skip=true
構(gòu)建鏡像,在dubbo-admin目錄下編寫Dockerfile文件,寫入以下內(nèi)容:
FROM openjdk:8-jdk-alpine
VOLUME /tmp
ADD ./target/dubbo-admin-0.0.1-SNAPSHOT.jar app.jar
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","app.jar"]
使用以下命令構(gòu)建鏡像
docker build -t dubbo-admin:1.0 .
編寫docker-compose.yml文件,在項(xiàng)目根目錄下編寫docker-compose.yml文件寫入以下內(nèi)容
version: '3.4'
services:
zk_server:
image: zookeeper:3.4
ports:
- 2181:2181
dubbo-admin:
image: dubbo-admin:1.0
links:
- zk_server:zookeeper
depends_on:
- zk_server
ports:
- 7001:7001
運(yùn)行compose項(xiàng)目,在docker-compose.yml文件所在目錄執(zhí)行:
docker-compose up
在瀏覽器中訪問(wèn)http://ip:7001 登錄驗(yàn)證,默認(rèn)用戶名密碼:root/root,guest/guest
執(zhí)行docker-compose [COMMAND] —help 或者docker-compose help [COMMAND]可以產(chǎn)看命令的使用幫助。
docker-compose命令的基本使用格式是:
docker-compose [-f=<arg>...][options][COMMAND][ARG...]
選項(xiàng)說(shuō)明:
-f, --file 指定模板文件,默認(rèn)為docker-compose.yml,可以多次指定
-p, --project-name 指定項(xiàng)目名稱,默認(rèn)使用所在目錄名稱作為項(xiàng)目名
--x-networking 使用Docker的可插拔網(wǎng)絡(luò)后端特性
--x-networking-driver 指定網(wǎng)絡(luò)后端的驅(qū)動(dòng),默認(rèn)為bridge
--verbose 輸出更多調(diào)試信息
-v, --version 打印版本并退出
模板文件是Compose的核心,其涉及的指令關(guān)鍵字也比較多,大部分指令跟docker run相關(guān)的參數(shù)含義類似。默認(rèn)的模板文件名稱為docker-compose.yml,格式為YAML格式。
每個(gè)服務(wù)都必須通過(guò)image指令指定鏡像或build指令(需要Dockerfile)等來(lái)自動(dòng)構(gòu)建鏡像。如果使用build指令,在Dockerfile中設(shè)置的選項(xiàng)(如:CMD,ENV 等)將會(huì)自動(dòng)被獲取,無(wú)需在docker-compose.yml文件中再次設(shè)置。
build
指定Dockerfile所在文件夾的路徑(可以是絕對(duì)路徑,也可以是相對(duì)于docker-compose.yml文件的路徑),Compose將會(huì)利用它自動(dòng)構(gòu)建鏡像,然后使用這個(gè)鏡像。
使用context指令指定Dockerfile文件所在文件夾的路徑
使用dockerfile指令指定Dockerfile的文件名
使用args令指定構(gòu)建鏡像時(shí)的變量
version: '3'
services:
webapp:
build:
context:./dir
dockerfile:Dockerfile
args:
buildno:1
command
覆蓋容器啟動(dòng)后默認(rèn)執(zhí)行的命令
command:echo "hello word"
container_name
指定容器名稱,默認(rèn)會(huì)使用 項(xiàng)目名稱服務(wù)名稱序號(hào) 這樣的格式
devices
指定設(shè)備映射關(guān)系
devices:
- "/dev/ttyUSB1:/dev/ttyUSB0"
depends_on
解決容器的依賴,啟動(dòng)先后的問(wèn)題
自定義DNS服務(wù)器,可以是一個(gè)值,也可以是一個(gè)列表
environment
設(shè)置環(huán)境變量,可以使用數(shù)組或字典兩種格式,指給定名稱的變量會(huì)自動(dòng)獲取Compose主機(jī)上對(duì)應(yīng)變量的值,可以用來(lái)防止泄露不必要的數(shù)據(jù)。
expose
暴露端口,但不映射到宿主機(jī),只被連接的服務(wù)訪問(wèn),僅可以指定內(nèi)部端口為參數(shù)。
extra_hosts
類似Docker中的—add-host參數(shù),指定額外的host名稱映射信息
extra_hosts:
- "googledns:8.8.8.8"
會(huì)在啟動(dòng)啟動(dòng)后的服務(wù)容器中 /etc/hosts 文件中添加“8.8.8.8 googledns”
healthcheck
通過(guò)命令檢查容器是否健康運(yùn)行
image
指定鏡像名稱或鏡像ID,如果鏡像在本地不存在會(huì)嘗試?yán)∵@個(gè)鏡像。
labels
為容器添加Docker元數(shù)據(jù)信息,如可以添加輔助說(shuō)明信息
network_mode
設(shè)置網(wǎng)絡(luò)模式,使用和docker run 的—network參數(shù)一樣的值
networks
配置容器連接的網(wǎng)絡(luò)
ports
暴露端口信息,使用 宿主端口:容器端口 的格式,只指定容器端口的時(shí)候,宿主端口會(huì)隨機(jī)映射。
volumes
數(shù)據(jù)卷掛載的路徑設(shè)置,可以設(shè)置宿主機(jī)路徑,同時(shí)支持相對(duì)路徑
ulimits
指定容器的ulimits限制值,如指定最大進(jìn)程數(shù)為66635,指定文件句柄數(shù)位為20000(軟限制,應(yīng)用可以隨時(shí)修改,不能超過(guò)硬限制)和40000(系統(tǒng)硬限制,只能root用戶提高)
ulimits:
nproc:65535
nofile:
soft:20000
hard:40000
entrypoint
指定服務(wù)容器啟動(dòng)后執(zhí)行的文件入口
user
指定容器中運(yùn)行應(yīng)用的用戶名
working_dir
指定容器中的工作目錄
Compose模板文件支持動(dòng)態(tài)讀取主機(jī)的系統(tǒng)環(huán)境變量和當(dāng)前目錄下的 .env 文件中的變量。
如,Compose文件將從運(yùn)行它的環(huán)境中讀取${MONGO_VERSION}的值,并寫入執(zhí)行命令
version:'3'
services:
db:
image:"mongo:${MONGO_VERSION}"
如果執(zhí)行MONGO_VERSION=3.4,docker-compose up則會(huì)啟動(dòng)一個(gè)mongo:3.4鏡像的容器
若當(dāng)前目錄下存在 .env 文件,則優(yōu)先從該文件中讀取變量的值
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。