Jib介紹
Jib 是 Google 開發(fā)的可以直接構(gòu)建 Java 應(yīng)用的 Docker 和 OCI 鏡像的類庫(kù),以 Maven 和 Gradle 插件形式提供。
通過(guò) Jib,Java 開發(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開源地址: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)文章希望大家以后多多支持腳本之家!