Spring Cloud中使用jib進(jìn)行docker部署的步驟詳解
Jib介紹
Jib 是 Google 開(kāi)發(fā)的可以直接構(gòu)建 Java 應(yīng)用的 Docker 和 OCI 鏡像的類庫(kù),以 Maven 和 Gradle 插件形式提供。
通過(guò) Jib,Java 開(kāi)發(fā)者可以使用他們熟悉的 Java 工具來(lái)構(gòu)建容器。Jib 是一個(gè)快速而簡(jiǎn)單的容器鏡像構(gòu)建工具,它負(fù)責(zé)處理將應(yīng)用程序打包到容器鏡像中所需的所有步驟。它不需要你編寫 Dockerfile 或安裝 Docker,而且可以直接集成到 Maven 和 Gradle中 —— 只需要將插件添加到構(gòu)建中,就可以立即將 Java 應(yīng)用程序容器化。
jib開(kāi)源地址:https://github.com/GoogleContainerTools/jib
普通方式Docker構(gòu)建流程
Jib構(gòu)建流程
集成Jib
項(xiàng)目是Spring Cloud,版本Hoxton.SR1。
集成jib只需要在pom里面加入jib的插件
<plugin> <groupId>com.google.cloud.tools</groupId> <artifactId>jib-maven-plugin</artifactId> <version>${jib.version}</version> </plugin>
jib相關(guān)完整配置
<properties> <!-- jib docker config--> <!-- jib 版本--> <jib.version>2.2.0</jib.version> <!-- 是否跳過(guò)jib打包--> <jib.skip>true</jib.skip> <!-- 倉(cāng)庫(kù)鏡像名稱--> <jib.repository.name>akk-system</jib.repository.name> <!-- 啟動(dòng)類--> <jib.main.class>com.akk.GatewayApplication</jib.main.class> <!-- 倉(cāng)庫(kù)登錄用戶名--> <REGISTRY_USERNAME>222222222222</REGISTRY_USERNAME> <!-- 倉(cāng)庫(kù)登錄密碼--> <REGISTRY_PASSWORD>111111111111</REGISTRY_PASSWORD> </properties>
<plugins> <plugin> <groupId>com.google.cloud.tools</groupId> <artifactId>jib-maven-plugin</artifactId> <version>${jib.version}</version> <configuration> <skip>${jib.skip}</skip> <!-- 配置基礎(chǔ)鏡像--> <from> <image>openjdk:8-jre-alpine</image> </from> <!-- 配置推送地址,倉(cāng)庫(kù)名,鏡像名--> <to> <image>registry.cn-hangzhou.aliyuncs.com/akk_java/${jib.repository.name}</image> <tags> <!-- <tag>${jib.repository.name}</tag>--> <!-- <tag>${version}</tag>--> </tags> <auth> <username>${REGISTRY_USERNAME}</username> <password>${REGISTRY_PASSWORD}</password> </auth> </to> <!--私服是http不是https,默認(rèn)jib不推送到非https的私服,私服添加,公服不添加--> <!-- <allowInsecureRegistries>true</allowInsecureRegistries>--> <container> <mainClass>${jib.main.class}</mainClass> <labels> <name>${artifactId}</name> </labels> </container> </configuration> <!--綁定到maven lifecicle--> <!-- <executions>--> <!-- <execution>--> <!-- <phase>package</phase>--> <!-- <goals>--> <!-- <goal>build</goal>--> <!-- </goals>--> <!-- </execution>--> <!-- </executions>--> </plugin> </plugins>
參數(shù)說(shuō)明:
${jib.version}
jib版本:自行選擇即可
${jib.skip}
是否跳過(guò)jib:jib插件放在根目錄下面的pom內(nèi),所以項(xiàng)目的所有模塊會(huì)進(jìn)行jib操作。如項(xiàng)目的公共依賴模塊不需打包的,可以重新定義此屬性,跳過(guò)jib
${jib.repository.name}
鏡像的推送倉(cāng)庫(kù)名稱:倉(cāng)庫(kù)名稱
${version}
鏡像版本:推送鏡像的版本
${REGISTRY_USERNAME}
鏡像倉(cāng)庫(kù)用戶名:私有倉(cāng)庫(kù)的登錄賬號(hào)
${REGISTRY_PASSWORD}
鏡像倉(cāng)庫(kù)密碼:私有倉(cāng)庫(kù)的登錄密碼
${jib.main.class}
項(xiàng)目模塊啟動(dòng)類:項(xiàng)目模塊的啟動(dòng)類,Spring boot啟動(dòng)類
form
標(biāo)簽定義了基礎(chǔ)鏡像,此處基于openjdk:8-jre-alpine
,可以使用其他。to
標(biāo)簽定義編譯后的鏡像推送信息,image
定義推送鏡像名稱信息,tags
推送鏡像的tag,可以通過(guò)tag拉取指定鏡像。 auth
定義私有倉(cāng)庫(kù)的登錄信息。container
定義鏡像的內(nèi)容信息,mainClass
啟動(dòng)的主類。labels
應(yīng)用元數(shù)據(jù)鍵值對(duì),類似于docker的label。下面的executions進(jìn)行了命令的綁定,此處將jib的build命令綁定到了maven的package命令上,當(dāng)運(yùn)行mvn package時(shí),會(huì)自動(dòng)執(zhí)行jib build。(更多配置標(biāo)簽參考https://github.com/GoogleContainerTools/jib/tree/master/jib-maven-plugin )
此時(shí)idea的maven菜單中就可以看到j(luò)ib插件相關(guān)內(nèi)容:
如:gateway模塊(需要打包鏡像),pom配置如下
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <parent> <artifactId>akk-system</artifactId> <groupId>com.akk</groupId> <version>0.0.1-SNAPSHOT</version> </parent> <modelVersion>4.0.0</modelVersion> <artifactId>gateway</artifactId> <properties> <!-- jib docker config--> <jib.version>2.2.0</jib.version> <jib.skip>false</jib.skip> <jib.repository.name>akk-gateway</jib.repository.name> <jib.main.class>com.akk.GatewayApplication</jib.main.class> </properties> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-gateway</artifactId> </dependency> <dependency> <groupId>com.github.xiaoymin</groupId> <artifactId>knife4j-spring-boot-starter</artifactId> </dependency> </dependencies> </project>
common公共依賴包pom(不需要打包鏡像):
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <artifactId>akk-system</artifactId> <groupId>com.akk</groupId> <version>0.0.1-SNAPSHOT</version> </parent> <artifactId>common</artifactId> <version>0.0.1-SNAPSHOT</version> <properties> <!-- jib docker config--> <jib.version>2.2.0</jib.version> <jib.skip>true</jib.skip> <jib.repository.name>akk-system</jib.repository.name> <jib.image.name>akk-system</jib.image.name> </properties> <dependencies> <!-- 依賴信息--> </dependencies> </project>
其中properties覆蓋了jib的相關(guān)參數(shù)配置。
打包鏡像
運(yùn)行mvn package jib:dockerBuild
進(jìn)行打包。
打包完成,查看本地docker鏡像(jib:dockerBuild 命令不會(huì)上傳鏡像,使用jib:build命令則會(huì)上傳鏡像)
打包并上傳鏡像
運(yùn)行mvn package jib:build
進(jìn)行打包并上傳。
登錄docker私有倉(cāng)庫(kù)
docker login --username=username --password=password registry.cn-hangzhou.aliyuncs.com
拉取鏡像
docker pull registry.cn-hangzhou.aliyuncs.com/akk_java/akk-gateway:latest
docker部署項(xiàng)目
微服務(wù)項(xiàng)目部署,模塊較多,一般為分布式集群環(huán)境,所以手動(dòng)部署比較麻煩,可以使用Jenkins類似的自動(dòng)化部署工具。使用Jenkins進(jìn)行打包上傳鏡像之后,登錄到遠(yuǎn)程服務(wù)器,執(zhí)行腳本進(jìn)行啟動(dòng)。如:
#!/bin/bash # 登錄docker倉(cāng)庫(kù) docker login --username=username --password=password registry.cn-hangzhou.aliyuncs.com # 停止運(yùn)行的容器 docker ps | grep akk_java | awk '{print $1}' | xargs docker stop # 刪除容器 docker ps -a -q | grep akk_java | awk '{print $1}' | xargs docker rm # 查詢鏡像文件并刪除 docker images | grep akk_java | awk '{print $3}' | xargs docker rmi # 拉取鏡像 docker pull registry.cn-hangzhou.aliyuncs.com/akk_java/akk-user:latest docker pull registry.cn-hangzhou.aliyuncs.com/akk_java/akk-gateway:latest docker pull registry.cn-hangzhou.aliyuncs.com/akk_java/akk-task:latest docker pull registry.cn-hangzhou.aliyuncs.com/akk_java/akk-store:latest docker pull registry.cn-hangzhou.aliyuncs.com/akk_java/akk-pay:latest docker pull registry.cn-hangzhou.aliyuncs.com/akk_java/akk-app-api:latest docker pull registry.cn-hangzhou.aliyuncs.com/akk_java/akk-sso-auth:latest docker pull registry.cn-hangzhou.aliyuncs.com/akk_java/akk-seata:latest
重新拉取鏡像之后,執(zhí)行docker run
命令啟動(dòng)docker就行了。
到此這篇關(guān)于Spring Cloud中使用jib進(jìn)行docker部署的步驟詳解的文章就介紹到這了,更多相關(guān)Spring Cloud docker部署內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用Docker?運(yùn)行?python?簡(jiǎn)單程序
這篇文章主要介紹了利用Docker?運(yùn)行?python?簡(jiǎn)單程序,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-04-04Prometheus 整合 AlertManager的教程詳解
Alertmanager 主要用于接收 Prometheus 發(fā)送的告警信息,它很容易做到告警信息的去重,降噪,分組,策略路由,是一款前衛(wèi)的告警通知系統(tǒng)。這篇文章主要介紹了Prometheus 整合 AlertManager的教程 ,需要的朋友可以參考下2019-07-07Docker獲取鏡像報(bào)錯(cuò)docker: Error response from daemon
這篇文章主要介紹了Docker獲取鏡像報(bào)錯(cuò)docker: Error response from daemon, 出現(xiàn)了鏡像獲取報(bào)錯(cuò)的問(wèn)題,找到了解決的方法記一下,需要的朋友可以參考下2018-08-08淺談關(guān)于Docker容器互聯(lián)的初步實(shí)踐
這篇文章主要介紹了淺談關(guān)于Docker容器互聯(lián)的初步實(shí)踐,本文介紹了使用網(wǎng)橋(bridge)來(lái)對(duì)容器進(jìn)行互聯(lián),非常具有實(shí)用價(jià)值,需要的朋友可以參考下2018-10-10在Docker構(gòu)建的容器中實(shí)現(xiàn)安裝ping工具
這篇文章主要介紹了在Docker構(gòu)建的容器中實(shí)現(xiàn)安裝ping工具,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11Docker容器訪問(wèn)宿主機(jī)網(wǎng)絡(luò)的方法
這篇文章主要介紹了Docker容器訪問(wèn)宿主機(jī)網(wǎng)絡(luò)的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-10-10