Jib介紹
Jib 是 Google 開發(fā)的可以直接構建 Java 應用的 Docker 和 OCI 鏡像的類庫,以 Maven 和 Gradle 插件形式提供。
通過 Jib,Java 開發(fā)者可以使用他們熟悉的 Java 工具來構建容器。Jib 是一個快速而簡單的容器鏡像構建工具,它負責處理將應用程序打包到容器鏡像中所需的所有步驟。它不需要你編寫 Dockerfile 或安裝 Docker,而且可以直接集成到 Maven 和 Gradle中 —— 只需要將插件添加到構建中,就可以立即將 Java 應用程序容器化。
jib開源地址:https://github.com/GoogleContainerTools/jib
普通方式Docker構建流程
Jib構建流程
集成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相關完整配置
<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>
<!-- 配置基礎鏡像-->
<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
標簽定義了基礎鏡像,此處基于openjdk:8-jre-alpine
,可以使用其他。to
標簽定義編譯后的鏡像推送信息,image
定義推送鏡像名稱信息,tags
推送鏡像的tag,可以通過tag拉取指定鏡像。 auth
定義私有倉庫的登錄信息。container
定義鏡像的內(nèi)容信息,mainClass
啟動的主類。labels
應用元數(shù)據(jù)鍵值對,類似于docker的label。下面的executions進行了命令的綁定,此處將jib的build命令綁定到了maven的package命令上,當運行mvn package時,會自動執(zhí)行jib build。(更多配置標簽參考https://github.com/GoogleContainerTools/jib/tree/master/jib-maven-plugin )
此時idea的maven菜單中就可以看到jib插件相關內(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的相關參數(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部署項目
微服務項目部署,模塊較多,一般為分布式集群環(huán)境,所以手動部署比較麻煩,可以使用Jenkins類似的自動化部署工具。使用Jenkins進行打包上傳鏡像之后,登錄到遠程服務器,執(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就行了。
到此這篇關于Spring Cloud中使用jib進行docker部署的步驟詳解的文章就介紹到這了,更多相關Spring Cloud docker部署內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!