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!
推薦閱讀:
- idea集合docker實現鏡像打包一鍵部署
- IDEA 配置Docker的過程
- IDEA使用Docker插件(菜鳥教程)
- springboot中的dockerfile使用
- Docker部署SpringBoot應用的實現步驟