Spring Cloud中使用jib進行docker部署的步驟詳解
Jib介紹
Jib 是 Google 開發(fā)的可以直接構(gòu)建 Java 應(yīng)用的 Docker 和 OCI 鏡像的類庫,以 Maven 和 Gradle 插件形式提供。
通過 Jib,Java 開發(fā)者可以使用他們熟悉的 Java 工具來構(gòu)建容器。Jib 是一個快速而簡單的容器鏡像構(gòu)建工具,它負責(zé)處理將應(yīng)用程序打包到容器鏡像中所需的所有步驟。它不需要你編寫 Dockerfile 或安裝 Docker,而且可以直接集成到 Maven 和 Gradle中 —— 只需要將插件添加到構(gòu)建中,就可以立即將 Java 應(yīng)用程序容器化。
jib開源地址:https://github.com/GoogleContainerTools/jib
普通方式Docker構(gòu)建流程
Jib構(gòu)建流程
集成Jib
項目是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> <!-- 是否跳過jib打包--> <jib.skip>true</jib.skip> <!-- 倉庫鏡像名稱--> <jib.repository.name>akk-system</jib.repository.name> <!-- 啟動類--> <jib.main.class>com.akk.GatewayApplication</jib.main.class> <!-- 倉庫登錄用戶名--> <REGISTRY_USERNAME>222222222222</REGISTRY_USERNAME> <!-- 倉庫登錄密碼--> <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> <!-- 配置推送地址,倉庫名,鏡像名--> <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,默認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ù)說明:
${jib.version}
jib版本:自行選擇即可
${jib.skip}
是否跳過jib:jib插件放在根目錄下面的pom內(nèi),所以項目的所有模塊會進行jib操作。如項目的公共依賴模塊不需打包的,可以重新定義此屬性,跳過jib
${jib.repository.name}
鏡像的推送倉庫名稱:倉庫名稱
${version}
鏡像版本:推送鏡像的版本
${REGISTRY_USERNAME}
鏡像倉庫用戶名:私有倉庫的登錄賬號
${REGISTRY_PASSWORD}
鏡像倉庫密碼:私有倉庫的登錄密碼
${jib.main.class}
項目模塊啟動類:項目模塊的啟動類,Spring boot啟動類
form
標(biāo)簽定義了基礎(chǔ)鏡像,此處基于openjdk:8-jre-alpine
,可以使用其他。to
標(biāo)簽定義編譯后的鏡像推送信息,image
定義推送鏡像名稱信息,tags
推送鏡像的tag,可以通過tag拉取指定鏡像。 auth
定義私有倉庫的登錄信息。container
定義鏡像的內(nèi)容信息,mainClass
啟動的主類。labels
應(yīng)用元數(shù)據(jù)鍵值對,類似于docker的label。下面的executions進行了命令的綁定,此處將jib的build命令綁定到了maven的package命令上,當(dāng)運行mvn package時,會自動執(zhí)行jib build。(更多配置標(biāo)簽參考https://github.com/GoogleContainerTools/jib/tree/master/jib-maven-plugin )
此時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ù)配置。
打包鏡像
運行mvn package jib:dockerBuild
進行打包。
打包完成,查看本地docker鏡像(jib:dockerBuild 命令不會上傳鏡像,使用jib:build命令則會上傳鏡像)
打包并上傳鏡像
運行mvn package jib:build
進行打包并上傳。
登錄docker私有倉庫
docker login --username=username --password=password registry.cn-hangzhou.aliyuncs.com
拉取鏡像
docker pull registry.cn-hangzhou.aliyuncs.com/akk_java/akk-gateway:latest
docker部署項目
微服務(wù)項目部署,模塊較多,一般為分布式集群環(huán)境,所以手動部署比較麻煩,可以使用Jenkins類似的自動化部署工具。使用Jenkins進行打包上傳鏡像之后,登錄到遠程服務(wù)器,執(zhí)行腳本進行啟動。如:
#!/bin/bash # 登錄docker倉庫 docker login --username=username --password=password registry.cn-hangzhou.aliyuncs.com # 停止運行的容器 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
命令啟動docker就行了。
到此這篇關(guān)于Spring Cloud中使用jib進行docker部署的步驟詳解的文章就介紹到這了,更多相關(guān)Spring Cloud docker部署內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Prometheus 整合 AlertManager的教程詳解
Alertmanager 主要用于接收 Prometheus 發(fā)送的告警信息,它很容易做到告警信息的去重,降噪,分組,策略路由,是一款前衛(wèi)的告警通知系統(tǒng)。這篇文章主要介紹了Prometheus 整合 AlertManager的教程 ,需要的朋友可以參考下2019-07-07Docker獲取鏡像報錯docker: Error response from daemon
這篇文章主要介紹了Docker獲取鏡像報錯docker: Error response from daemon, 出現(xiàn)了鏡像獲取報錯的問題,找到了解決的方法記一下,需要的朋友可以參考下2018-08-08淺談關(guān)于Docker容器互聯(lián)的初步實踐
這篇文章主要介紹了淺談關(guān)于Docker容器互聯(lián)的初步實踐,本文介紹了使用網(wǎng)橋(bridge)來對容器進行互聯(lián),非常具有實用價值,需要的朋友可以參考下2018-10-10在Docker構(gòu)建的容器中實現(xiàn)安裝ping工具
這篇文章主要介紹了在Docker構(gòu)建的容器中實現(xiàn)安裝ping工具,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11