這兩天發(fā)現(xiàn)個Gradle插件,支持一鍵打包、推送Docker鏡像。今天我們來講講這個插件,希望對大家有所幫助!
Gradle Docker Plugin 簡介
一款可以通過遠(yuǎn)程API管理Docker鏡像和容器的插件,專為Java應(yīng)用打造,原生支持SpringBoot。
使用該插件具有如下特性:
- 與構(gòu)建工具Gradle及其DSL無縫集成。
- 在幕后處理Docker客戶端和守護(hù)程序之間的復(fù)雜通信邏輯。
- 簡化了復(fù)雜工作流程的定義。
- 最大程度地減少構(gòu)建腳本的編寫邏輯。
該插件由以下三個插件組成:
-
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鏡像。
操作鏡像
還是以我的腳手架項目
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é)點下面定義一個常量,這里定義好了鏡像倉庫地址,方便我們之后引用;
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 - 讓我們看下控制臺輸出的日志,其實就是給我們默認(rèn)創(chuàng)建了一個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'.
- 在項目的
build\docker
文件夾下可以發(fā)現(xiàn)這個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
- 打包完鏡像之后,直接使用如下命令即可運行項目,注意安裝好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
推送鏡像
- 接下來我們試試推送鏡像功能,不過首先需要安裝一個鏡像倉庫,
- 推送鏡像也是非常簡單的,直接在IDEA中使用
dockerPushImage
命令即可;
image.png -
推送完成后,在我們的可視化鏡像倉庫中就可以看到該鏡像了。
image.png
對比Maven
我們通過把項目clean以后再打包成Docker鏡像,對比下使用Gradle和Maven的速度。
- 使用Gradle進(jìn)行clean并構(gòu)建Docker鏡像,耗時
30s
;
image.png - 使用Maven進(jìn)行clean并構(gòu)建Docker鏡像,耗時
58s
,果然Gradle還是能比Maven快一倍的!
image.png
總結(jié)
今天我們體驗了一把Gradle和Docker結(jié)合使用,發(fā)現(xiàn)真是夠快夠簡單。對比Maven速度快了一倍,內(nèi)置了Dockerfile,大大降低了配置難度。