Spring Cloud中使用jib進行docker部署的步驟詳解
Jib介紹
Jib 是 Google 開發(fā)的可以直接構(gòu)建 Java 應用的 Docker 和 OCI 鏡像的類庫,以 Maven 和 Gradle 插件形式提供。
通過 Jib,Java 開發(fā)者可以使用他們熟悉的 Java 工具來構(gòu)建容器。Jib 是一個快速而簡單的容器鏡像構(gòu)建工具,它負責處理將應用程序打包到容器鏡像中所需的所有步驟。它不需要你編寫 Dockerfile 或安裝 Docker,而且可以直接集成到 Maven 和 Gradle中 —— 只需要將插件添加到構(gòu)建中,就可以立即將 Java 應用程序容器化。
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相關完整配置
<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ù)瀏覽下面的相關文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學習參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。