maven實現docker自動化部署插件的使用

構建開發項目

首先打開我們的IDEA構建一個我們的開發項目,配置如下:

在這裡插入圖片描述

接著打開我們的pom.xml修改build的配置,修改以後的代碼如下:

<build>
        <finalName>docker-automation-demo</finalName>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>

            <plugin>
                <groupId>com.github.lazyBoyl</groupId>
                <artifactId>docker-maven-plugin</artifactId>
                <version>1.0-release</version>
                <configuration>
                    <!-- 需要上傳到服務器的jar包所在的位置 -->
                    <jarTargetPath>${basedir}/target/docker-automation-demo.jar</jarTargetPath>
                    <!-- 創建鏡像的dockerFile的本地配置文件的路徑 -->
                    <dockerFilePath>${basedir}/dockerFile/Dockerfile</dockerFilePath>
                    <!-- 我們的dockerFile文件和相應的jar包的文件上傳到服務器的路徑 -->
                    <dockerImagesPath>/home/app/docker/test/</dockerImagesPath>
                    <!-- 該工程啟動的時候的日志文件的掛載,前面的為本地的服務器的路徑,分號後面的為docker容器中的文件路徑 -->
                    <containerRunShare>/home/app/logs/docker-plugin-test/log/:/app/www/logs/docker-plugin-test/log/</containerRunShare>
                    <!-- 該工程啟動的時候的端口映射,多個端口那就對應著啟動多少個容器 -->
                    <containerRunPorts>
                        <containerRunPort>8088:8088</containerRunPort>
                    </containerRunPorts>
                    <options>
                        <!-- 服務器的ip:端口,賬號,密碼 -->
                        <option>
                            10.10.10.114:22,root,123456
                        </option>
                    </options>
                </configuration>
                <executions>
                    <execution>
                        <!-- 設置該插件的執行的生命周期為package完成以後執行,若不想綁定就將executions這塊的代碼註釋瞭,後面就不會在打包好以後再去執行docker插件的操作 -->
                        <phase>package</phase>
                        <goals>
                            <!--phase與goal是綁定的關系,當g到達瞭phase階段的時候就會去執行goal,此處的值固定為dockerMavenPlugin,因為插件給予他的名字就是dockerMavenPlugin -->
                            <goal>dockerMavenPlugin</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

接著我們在我們的主入口類的同級目錄底下創建一個controller包,同時在該目錄底下創建一個測試的TestController.java的測試入口類,代碼如下:

package com.docker.automation.demo.controller;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

/**
 * @author linzf
 * @since 2019/5/28
 * 類描述:
 */
@RestController
@RequestMapping("/test")
public class TestController {

    private Logger logger = LoggerFactory.getLogger(TestController.class);

    /**
     * 功能描述:實現消息的發送
     *
     * @param msg 前端發送的消息
     * @return 返回結果
     */
    @GetMapping("sendMsg")
    public String sendMsg(@RequestParam("msg") String msg) {
        logger.debug("收到請求過來的消息:{}", msg);
        return msg;
    }

}

最後記得在application.yml裡面配置上我們的端口未8088

配置dockerFile的配置文件

接著在工程的src的同級目錄創建一個dockerFile文件夾,同時在該文件夾底下創建一個Dockerfile文件

在這裡插入圖片描述

接著打開DockerFile配置文件配置信息如下:

FROM base-jdk
   MAINTAINER linzf <[email protected]>
   RUN mkdir -p /app/www/logs/docker-automation-demo/log/
   RUN mkdir -p /home/app/
   ADD docker-automation-demo.jar /home/app/app.jar
   CMD java -jar -Xms128m -Xmx1536m /home/app/app.jar

到此處我們就完成瞭我們的工程的docker的配置,如何創建基礎鏡像、如何部署docker這些大傢可以直接看我的docker系列文章:https://blog.csdn.net/linzhefeng89/article/details/78413387

最後我們直接點擊我們IDEA的package命令進行打包,那麼我們的maven插件會自動幫我們將我們的包打包部署到我們的docker容器中。

在這裡插入圖片描述

接著我們直接訪問我們的微服務的地址:http://10.10.10.114:8088/test/sendMsg?msg=wytuy

到此為止我們就完成瞭我們的自動化部署插件的講解,具體代碼請查看github的地址:
https://github.com/lazyboyl/docker-automation-demo

到此這篇關於maven實現docker自動化部署插件的使用的文章就介紹到這瞭,更多相關maven docker自動化部署內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: