簡(jiǎn)介
docker-compose項(xiàng)目是docker官方的開源項(xiàng)目,負(fù)責(zé)實(shí)現(xiàn)對(duì)docker容器集群的快速編排。compose允許用戶通過(guò)一個(gè)單獨(dú)的docker-compose.yml模板文件(yaml 格式)來(lái)定義一組相關(guān)聯(lián)的應(yīng)用容器為一個(gè)項(xiàng)目(project)。docker-compose項(xiàng)目由python編寫,調(diào)用docker服務(wù)提供的api來(lái)對(duì)容器進(jìn)行管理。因此,只要所操作的平臺(tái)支持docker api,就可以在其上利用compose來(lái)進(jìn)行編排管理。
docker-compose將所管理的容器分為三層,分別是工程(project),服務(wù)(service)以及容器(container)。docker-compose運(yùn)行目錄下的所有文件(docker-compose.yml,extends文件或環(huán)境變量文件等)組成一個(gè)工程,若無(wú)特殊指定工程名即為當(dāng)前目錄名。一個(gè)工程當(dāng)中可包含多個(gè)服務(wù),每個(gè)服務(wù)中定義了容器運(yùn)行的鏡像,參數(shù),依賴。一個(gè)服務(wù)當(dāng)中可包括多個(gè)容器實(shí)例,docker-compose并沒(méi)有解決負(fù)載均衡的問(wèn)題,因此需要借助其它工具實(shí)現(xiàn)服務(wù)發(fā)現(xiàn)及負(fù)載均衡。
docker-compose的工程配置文件默認(rèn)為docker-compose.yml,可通過(guò)環(huán)境變量compose_file或-f參數(shù)自定義配置文件,其定義了多個(gè)有依賴關(guān)系的服務(wù)及每個(gè)服務(wù)運(yùn)行的容器。
使用一個(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ù)載均衡容器等。
常用命令
docker-compose
介紹
compose的作用是“定義和運(yùn)行多個(gè)docker容器的應(yīng)用”。使用compose,你可以在一個(gè)配置文件(yaml格式)中配置你應(yīng)用的服務(wù),然后使用一個(gè)命令,即可創(chuàng)建并啟動(dòng)配置中引用的所有服務(wù)。
compose中兩個(gè)重要概念:
• 服務(wù) (service):一個(gè)應(yīng)用的容器,實(shí)際上可以包括若干運(yùn)行相同鏡像的容器實(shí)例。
• 項(xiàng)目 (project):由一組關(guān)聯(lián)的應(yīng)用容器組成的一個(gè)完整業(yè)務(wù)單元,在 docker-compose.yml文件中定義。
docker compose的安裝
compose的安裝有多種方式,本文講解通過(guò)shell安裝的方式。其他安裝方式如有興趣,
可以查看docker的官方文檔:https://docs.docker.com/compose/install/
docker compose安裝步驟
通過(guò)github鏈接下載安裝 非root用戶記得加sudo
sudo curl -l "https://github.com/docker/compose/releases/download/1.25.5/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
給二進(jìn)制下載文件可執(zhí)行的權(quán)限
sudo chmod +x /usr/local/bin/docker-compose
驗(yàn)證是否安裝
docker-compose --version
卸載
如果是二進(jìn)制包方式安裝的,刪除二進(jìn)制文件即可
rm /usr/local/bin/docker-compose
目錄結(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
示例
compose的使用非常簡(jiǎn)單,只需要編寫一個(gè)docker-compose.yml,然后使用docker-compose 命令操作即可。docker-compose.yml描述了容器的配置,而docker-compose 命令描述了對(duì)容器的操作。
1.我們使用一個(gè)微服務(wù)項(xiàng)目先來(lái)做一個(gè)簡(jiǎn)單的例子,首先創(chuàng)建一個(gè)compose的工作目錄,然后創(chuàng)建一個(gè)jenkinstest文件夾,里面放可執(zhí)行jar包和編寫一個(gè)dockerfile文件,目錄結(jié)構(gòu)如下:
jenkins里面存放自己測(cè)試上傳的jar包
docker-compose.yml
version: '3.1' #這里要指定docker-compose對(duì)應(yīng)的docker版本 services: jenkinstest: #指定服務(wù)名 #image: jenkinstest #指定鏡像名稱 小寫不然會(huì)報(bào)錯(cuò) build: ./jenkinstest #指定dockfile所在路徑 ports: - 8099:8099 #指定端口映射 expose: - 8099 #對(duì)外暴露的服務(wù)端口
dockerfile文件
from adoptopenjdk/openjdk8:jdk8u-centos-nightly #作者 maintainer lkz # 鏡像要暴露的端口,如要使用端口,在執(zhí)行docker run命令時(shí)使用-p生效 expose 8099 copy jenkinstest.jar 11.jar # 在鏡像運(yùn)行為容器后執(zhí)行的命令 entrypoint ["java","-jar","11.jar"]
啟動(dòng)微服務(wù),可以加上參數(shù)-d后臺(tái)啟動(dòng)
docker-compose up -d
使用docker compose編排springcloud微服務(wù)
配置同上
修改docker-compose.yml文件
version: '3.3' services: eureka: image: eureka:v1 #指定鏡像名稱 build: ./eureka #指定dockfile所在路徑 ports: - 8080:8080 user: image: user:v1 build: ./user #指定dockfile所在路徑 ports: - 8081:8081 power: image: power:v1 build: ./power #指定dockfile所在路徑 ports: - 8082:8082
到此這篇關(guān)于docker-compose鏡像發(fā)布springboot項(xiàng)目的流程分析的文章就介紹到這了,更多相關(guān)docker-compose發(fā)布springboot項(xiàng)目?jī)?nèi)容請(qǐng)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!
原文鏈接:https://blog.csdn.net/qq_43049310/article/details/118020915