教你如何利用docker-maven-plugin自动化部署
1、docker-maven-plugin 介绍
在我们持续集成过程中,项目工程一般使用 Maven 编译打包,然后生成镜像,通过镜像上线,能够大大提供上线效率,同时能够快速动态扩容,快速回滚,着实很方便。docker-maven-plugin 插件就是为了帮助我们在Maven工程中,通过简单的配置,自动生成镜像并推送到仓库中。
**作用:
在编译工程时,能自动生成docker image,还可以远程推送至仓库,只需要在maven的配置文件pom.xml中合理的配置**
例子一(编译时自动生成docker镜像):
1、maven 配置:
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>1.0.0</version>
<configuration>
<!--注意imageName一定要是符合正则[a-z0-9-_.]的,否则构建不会成功-->
<imageName>myserver:v1</imageName>
<!-- 指定了Dockfile的目录,所以需要在项目的class="lazy" data-src/main下创建一个docker目录,并在其目录中配置Dockerfile文件 -->
<dockerDirectory>${project.basedir}/class="lazy" data-src/main/resources/docker</dockerDirectory>
<skipDockerBuild>false</skipDockerBuild>
<!-- resources的内容会复制 dockerDirectory(也就是构建上下文)中 -->
<resources>
<resource>
<targetPath>/</targetPath>
<directory>${project.build.directory}</directory>
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>
2、然后在项目的class="lazy" data-src\main\resources\docker(就是上面配置的dockerDirectory目录),创建一个名为Dockerfile的文件内容如下:
FROM java:8
MAINTAINER blue
ADD mydocker-0.0.1-SNAPSHOT.jar mydocker.jar
ENTRYPOINT ["java", "-jar", "/mydocker.jar"]
3、设置系统环境变量,用于指定需要连接的docker daemon的主机和端口
前面讲过,docker是C/S架构,docker-maven-plugin担任client角色,服务器则需要环境变量指定
4、执行mvn clean install docker:build,项目编译完成后自动构建镜像,执行docker images查看镜像是否存在:
例子二(镜像推送至仓库,基于例子一):
1、打开maven配置文件 setting.xml,加入仓库账号信息:
<servers>
<server>
<id>docker-hub</id>
<username>blueiii</username>
<password>xxxx</password>
<configuration>
<email>xxxxx@163.com</email>
</configuration>
</server>
</servers>
2、修改pom.xml文件,imageName必须跟仓库路径一致:
<imageName>blueiii/mydocker:v1</imageName>
3、修改pom.xml文件,增加如下配置
<pushImage>true</pushImage>
<serverId>docker-hub</serverId>
<registryUrl>https://hub.docker.com/</registryUrl>
4、同样执行mvn clean install docker:build,自动构建镜像并上传至docker hub:
到此这篇关于教你如何利用docker-maven-plugin自动化部署的文章就介绍到这了,更多相关docker maven plugin自动化部署内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341