Docker一鍵部署 SpringBoot 應(yīng)用的方法,賊快賊好用!

這兩天發(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,大大降低了配置難度。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容