一鍵部署 Spring Boot 到遠程 Docker 容器,就是這么秀!


不知道各位小伙伴在生產環境都是怎么部署 Spring Boot 的,打成 jar 直接一鍵運行?打成 war 扔到 Tomcat 容器中運行?不過據松哥了解,容器化部署應該是目前的主流方案。

不同於傳統的單體應用,微服務由於服務數量眾多,在部署的時候出問題的可能性更大,這個時候,結合 Docker 來部署,就可以很好的解決這個問題,這也是目前使用較多的方案之一。

將 Spring Boot 項目打包到 Docker 容器中部署,有很多不同的方法,今天松哥主要來和大家聊一聊如何將 Spring Boot 項目一鍵打包到遠程 Docker 容器,然后通過運行一個鏡像的方式來啟動一個 Spring Boot 項目。

至於其他的 Spring Boot 結合 Docker 的用法,大家不要着急,后續的文章,松哥會和大家慢慢的一一道來。

1.准備工作

1.1 准備 Docker

我這里以 CentOS7 為例來給大家演示。

首先需要在 CentOS7 上安裝好 Docker,這個安裝方式網上很多,我就不多說了,我自己去年寫過一個 Docker 入門教程,大家可以在公眾號后台回復 Docker 獲取教程下載地址。

Docker 安裝成功之后,我們首先需要修改 Docker 配置,開啟允許遠程訪問 Docker 的功能,開啟方式很簡單,修改 /usr/lib/systemd/system/docker.service 文件,加入如下內容:

-H tcp://0.0.0.0:2375  -H unix:///var/run/docker.sock

如下圖:

配置完成后,保存退出,然后重啟 Docker:

systemctl daemon-reload    
service docker restart 

Docker 重啟成功之后,Docker 的准備工作就算是 OK 了。

1.2 准備 IDEA

IDEA 上的准備工作,主要是安裝一個 Docker 插件,點擊 File->Settings->Plugins->Browse Repositories 如下:

點擊右邊綠色的 Install 按鈕,完成安裝,安裝完成之后需要重啟一下 IDEA。

IDEA 重啟成功之后,我們依次打開 File->Settings->Build,Execution,Deployment->Docker ,然后配置一下 Docker 的遠程連接地址:

配置一下 Docker 的地址,配置完成后,可以看到下面有一個 Connection successful 提示,這個表示 Docker 已經連接上了。

如此之后,我們的准備工作就算是 OK 了。

2.准備項目

接下來我們來創建一個簡單的 Spring Boot 項目(只需要引入 spring-boot-starter-web 依賴即可),項目創建成功之后,我們再創建一個普通的 HelloDockerController,用來做測試,如下:

@RestController
public class HelloDockerController {
    @GetMapping("/hello")
    public String hello() {
        return "hello docker!";
    }
}

這是一個很簡單的接口,無需多說。

3.配置 Dockerfile

接下來,在項目的根目錄下,我創建一個 Dockerfile ,作為我鏡像的構建文件,具體位置如下圖:

文件內容如下:

FROM hub.c.163.com/library/java:latest
VOLUME /tmp
ADD target/docker-0.0.1-SNAPSHOT.jar app.jar
ENTRYPOINT ["java","-jar","/app.jar"]

這里只有簡單的四行,我說一下:

  1. Spring Boot 項目的運行依賴 Java 環境,所以我自己的鏡像基於 Java 鏡像來構建。
  2. 考慮到 Docker 官方鏡像下載較慢,我這里使用了網易提供的 Docker 鏡像。
  3. 由於 Spring Boot 運行時需要 tmp 目錄,這里數據卷配置一個 /tmp 目錄出來。
  4. 將本地 target 目錄中打包好的 .jar 文件復制一份新的 到 /app.jar。
  5. 最后就是配置一下啟動命令,由於我打包的 jar 已經成為 app.jar 了,所以啟動命令也是啟動 app.jar。

這是我們配置的一個簡單的 Dockerfile。

4.配置 Maven 插件

接下來在 pom.xml 文件中,添加如下插件:

<plugin>
    <groupId>com.spotify</groupId>
    <artifactId>docker-maven-plugin</artifactId>
    <version>1.2.0</version>
    <executions>
        <execution>
            <id>build-image</id>
            <phase>package</phase>
            <goals>
                <goal>build</goal>
            </goals>
        </execution>
    </executions>
    <configuration>
        <dockerHost>http://192.168.66.131:2375</dockerHost>
        <imageName>javaboy/${project.artifactId}</imageName>
        <imageTags>
            <imageTag>${project.version}</imageTag>
        </imageTags>
        <forceTags>true</forceTags>
        <dockerDirectory>${project.basedir}</dockerDirectory>
        <resources>
            <resource>
                <targetPath>/</targetPath>
                <directory>${project.build.directory}</directory>
                <include>${project.build.finalName}.jar</include>
            </resource>
        </resources>
    </configuration>
</plugin>

這個插件的配置不難理解:

  1. 首先在 execution 節點中配置當執行 mvn package 的時候,順便也執行一下 docker:build
  2. 然后在 configuration 中分別配置 Docker 的主機地址,鏡像的名稱,鏡像的 tags,其中 dockerDirectory 表示指定 Dockerfile 的位置。
  3. 最后 resource 節點中再配置一下 jar 的位置和名稱即可。

OK,做完這些我們就算大功告成了。

5.打包運行

接下來對項目進行打包,打包完成后,項目會自動構建成一個鏡像,並且上傳到 Docker 容器中,打包方式如下:

打包過程會稍微有一點舊,因為還包含了鏡像的構建,特別是第一次打包,需要下載基礎鏡像,會更慢一些。

部分打包日志如下(項目構建過程):

項目打包成功之后,我們就可以在 Docker 容器中看到我們剛剛打包成的鏡像了,如下:

5.1 運行方式一

此時,我們可以直接在 Linux 上像創建普通容器一樣創建這個鏡像的容器,然后啟動,執行如下命令即可:

docker run -d --name javaboy -p 8080:8080 javaboy/docker:0.0.1

啟動成功之后,我們就可以訪問容器中的接口了。

但是這種操作顯然還是有點麻煩,結合我們一開始安裝的 Docker 插件,這個運行步驟還可以做進一步的簡化。

5.2 運行方式二

大家注意,此時我們的 IDEA 中多了一個選項,就是 docker,如下:

點擊左邊的綠色啟動按鈕,連接上 Docker 容器,連接成功之后,我們就可以看到目前 Docker 中的所有容器和鏡像了,當然也包括我們剛剛創建的 Docker 鏡像,如下:

此時,我們選中這個鏡像,右鍵單擊,即可基於此鏡像創建出一個容器,如下圖:

我們選擇 Create container,然后填入容器的一些必要信息,配置一下容器名稱,鏡像 ID 會自動填上,暴露的端口使用 Specify 即可,然后寫上端口的映射關系:

配置完成后,點擊下方的 run 按鈕,就可以開始運行了。運行日志如下:

注意,這個日志是在 Docker 的那個窗口里打印出來的。

項目運行成功之后,在瀏覽器輸入遠程服務器的地址,就可以訪問了:

如此之后,我們的 Spring Boot 項目就算順利發布到遠程 Docker 容器中了。

好玩嗎?試試!

本文案例我已經上傳到 GitHub,小伙伴們可以參考:https://github.com/lenve/javaboy-code-samples​


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM