這兩天發(fā)現(xiàn)個(gè)Gradle插件,支持一鍵打包、推送Docker鏡像。今天我們來講講這個(gè)插件,希望對大家有所幫助!
Gradle Docker Plugin 簡介
一款可以通過遠(yuǎn)程API管理Docker鏡像和容器的插件,專為Java應(yīng)用打造,原生支持SpringBoot。
使用該插件具有如下特性:
- 與構(gòu)建工具Gradle及其DSL無縫集成。
- 在幕后處理Docker客戶端和守護(hù)程序之間的復(fù)雜通信邏輯。
- 簡化了復(fù)雜工作流程的定義。
- 最大程度地減少構(gòu)建腳本的編寫邏輯。
該插件由以下三個(gè)插件組成:
-
com.bmuschko.docker-remote-api:提供自定義任務(wù),可以通過遠(yuǎn)程API與Docker進(jìn)行交互。 -
com.bmuschko.docker-java-application:為Java應(yīng)用創(chuàng)建并推送Docker鏡像。 -
com.bmuschko.docker-spring-boot-application:為SpringBoot應(yīng)用創(chuàng)建并推送Docker鏡像。
操作鏡像
還是以我的腳手架項(xiàng)目
mall-tiny為例,讓我們來看看使用該插件打包推送Docker鏡像是不是夠快夠簡單!
構(gòu)建鏡像
- 要使用該插件,我們需要在
build.gradle中進(jìn)行如下配置,這里選擇使用遠(yuǎn)程API插件和SpringBoot插件;
plugins {
id 'com.bmuschko.docker-remote-api' version '6.7.0'
id 'com.bmuschko.docker-spring-boot-application' version '6.7.0'
}
- 然后在
ext節(jié)點(diǎn)下面定義一個(gè)常量,這里定義好了鏡像倉庫地址,方便我們之后引用;
ext{
registryUrl='192.168.5.78:5000'
}
- 接下來就是非常重要的插件配置了,配置好Docker遠(yuǎn)程API的訪問路徑,還有SpringBoot應(yīng)用鏡像相關(guān)配置;
docker {
url = 'tcp://192.168.5.78:2375'
springBootApplication {
baseImage = 'java:8'
maintainer = 'macrozheng'
ports = [8080]
images = ["${registryUrl}/mall-tiny/${rootProject.name}:${version}"]
jvmArgs = ['-Dspring.profiles.active=prod']
}
}
-
接下來我們來解讀下這些配置到底有什么作用;
image.png - 接下來我們直接在IDEA中使用
dockerBuildImage命令,即可將應(yīng)用鏡像打包到遠(yuǎn)程服務(wù)器上去;
image.png - 讓我們看下控制臺(tái)輸出的日志,其實(shí)就是給我們默認(rèn)創(chuàng)建了一個(gè)Dockerfile(連Dockerfile都省的寫了),然后用它來打包Docker鏡像;
> Task :dockerBuildImage
Building image using context 'I:\developer\gitee\mall-tiny-gradle\build\docker'.
Using images '192.168.5.78:5000/mall-tiny/mall-tiny:1.0.0-SNAPSHOT'.
Step 1/8 : FROM java:8
---> d23bdf5b1b1b
Step 2/8 : LABEL maintainer=macrozheng
---> Running in 9a63f56a03ae
Removing intermediate container 9a63f56a03ae
---> ed45af8fff90
Step 3/8 : WORKDIR /app
---> Running in 8bd4b513eb23
Removing intermediate container 8bd4b513eb23
---> d27759d1d7df
Step 4/8 : COPY libs libs/
---> 84c3a983972a
Step 5/8 : COPY resources resources/
---> c8a27f3475fc
Step 6/8 : COPY classes classes/
---> 3a76a8efc02b
Step 7/8 : ENTRYPOINT ["java", "-Dspring.profiles.active=prod", "-cp", "/app/resources:/app/classes:/app/libs/*", "com.macro.mall.tiny.MallTinyApplication"]
---> Running in e56ae56fd6eb
Removing intermediate container e56ae56fd6eb
---> 22d73f95e756
Step 8/8 : EXPOSE 8080
---> Running in b21d898456cb
Removing intermediate container b21d898456cb
---> 73684cf8c643
Successfully built 73684cf8c643
Successfully tagged 192.168.5.78:5000/mall-tiny/mall-tiny:1.0.0-SNAPSHOT
Created image with ID '73684cf8c643'.
BUILD SUCCESSFUL in 34s
5 actionable tasks: 5 executed
10:56:15: Task execution finished 'dockerBuildImage'.
- 在項(xiàng)目的
build\docker文件夾下可以發(fā)現(xiàn)這個(gè)Dockerfile,具體內(nèi)容如下:
FROM java:8
LABEL maintainer=macrozheng
WORKDIR /app
COPY libs libs/
COPY resources resources/
COPY classes classes/
ENTRYPOINT ["java", "-Dspring.profiles.active=prod", "-cp", "/app/resources:/app/classes:/app/libs/*", "com.macro.mall.tiny.MallTinyApplication"]
EXPOSE 8080
- 打包完鏡像之后,直接使用如下命令即可運(yùn)行項(xiàng)目,注意安裝好MySQL和Redis。
docker run -p 8080:8080 --name mall-tiny \
--link mysql:db \
--link redis:redis \
-v /etc/localtime:/etc/localtime \
-v /mydata/app/mall-tiny/logs:/var/logs \
-d 192.168.5.78:mall-tiny/mall-tiny:1.0.0-SNAPSHOT
推送鏡像
- 接下來我們試試推送鏡像功能,不過首先需要安裝一個(gè)鏡像倉庫,
- 推送鏡像也是非常簡單的,直接在IDEA中使用
dockerPushImage命令即可;
image.png -
推送完成后,在我們的可視化鏡像倉庫中就可以看到該鏡像了。
image.png
對比Maven
我們通過把項(xiàng)目clean以后再打包成Docker鏡像,對比下使用Gradle和Maven的速度。
- 使用Gradle進(jìn)行clean并構(gòu)建Docker鏡像,耗時(shí)
30s;
image.png - 使用Maven進(jìn)行clean并構(gòu)建Docker鏡像,耗時(shí)
58s,果然Gradle還是能比Maven快一倍的!
image.png
總結(jié)
今天我們體驗(yàn)了一把Gradle和Docker結(jié)合使用,發(fā)現(xiàn)真是夠快夠簡單。對比Maven速度快了一倍,內(nèi)置了Dockerfile,大大降低了配置難度。





