docker-maven-plugin
我们常见开源项目中使用的 Docker Maven 插件是com.spotify:docker-maven-plugin
。可用版本信息见Github。
通过其介绍可知该插件已经不再推荐使用,取而代之的是com.spotify:dockerfile-maven-plugin
,Github地址。
使用该插件可以在mvn
命令中直接构建出 Docker 镜像和完成推送等。
dockerfile-maven-plugin
要求用户必须提供 Dockerfile 用于构建镜像,从而将 Docker 镜像的构建依据统一到 Dockerfile 上,这与过时的docker-maven-plugin
是不同的。
相比 docker-maven-plugin 更加灵活安全
也能够绑定 Docker 命令到 Maven 各生命周期
Maven Goals 命令
Goals available for this plugin:
Maven 命令执行顺序
mvn package
mvn dockerfile:build
mvn verify
mvn dockerfile:push
mvn deploy
复制代码
Skip Docker Goals Bound to Maven Phases(跳过)
You can pass options to maven to disable the docker goals.
For example, to skip the entire dockerfile plugin:
mvn clean package -Ddockerfile.skip
复制代码
Configuration
Build Phase
https://github.com/spotify/dockerfile-maven/tree/master/plugin/src/it
注意事项(准备工作)
该插件需要 Java 7 或更高版本以及 Apache Maven 3 或更高版本(dockerfile-maven-plugin <= 1.4.6 需要 Maven> = 3,在其他情况下需要 Maven> = 3.5.2)。
要运行集成测试或在实践中使用插件,需要有效的 Docker 设置。
1. 有一台 Docker daemon 主机
镜像的制作以及推送操作,都是由 Docker 来完成的,所以,必须要安装 Docker 环境。简单的说 dockerfile-maven-plugin 只是简化了直接操作 Docker 的复杂度,该是 Docker 完成的事情,还得由 Docker 来完成。所以,明白这一点之后,就知道了并不是一定要在本地安装 Docker 环境,只要有 Docker 环境就可以了。
Docker开启远程API
3. 配置DOCKER_HOST
选项
要使用服务器的 Docker 环境,需要配置一个环境变量(默认情况下,插件是连接本地的 Docker 环境,即 127.0.0.1)
环境变量的配置如下,改成你自己的服务器 Docker 环境即可(可能需要重启电脑):DOCKER_HOST tcp://192.168.1.6:2375
4. 镜像仓库认证信息
该插件构建和发布镜像依赖于镜像仓库,需要用户提供镜像仓库的登录信息,支持 POM 设置和 Settings 设置
具体参考:dockerfile-maven/authentication.md at master · spotify/dockerfile-maven · GitHub
pom.xml 方式
从 1.3.XX 版开始,你可以使用 pom 本身的 config 进行身份验证。只需添加类似于以下内容的配置:
<plugin>
<groupId>com.spotify</groupId>
<artifactId>dockerfile-maven-plugin</artifactId>
<version>${version}</version>
<configuration>
<username>repoUserName</username>
<password>repoPassword</password>
<repository>${docker.image.prefix}/${project.artifactId}</repository>
<buildArgs>
<JAR_FILE>target/${project.build.finalName}.jar</JAR_FILE>
</buildArgs>
</configuration>
</plugin>
复制代码
或者
<plugin>
<groupId>com.spotify</groupId>
<artifactId>dockerfile-maven-plugin</artifactId>
<version>${version}</version>
<configuration>
<repository>${docker.image.prefix}/${project.artifactId}</repository>
<buildArgs>
<JAR_FILE>target/${project.build.finalName}.jar</JAR_FILE>
</buildArgs>
</configuration>
</plugin>
复制代码
然后使用命令
mvn goal -Ddockerfile.username=... -Ddockerfile.password=...
复制代码
Maven 多模块工程
Pom 配置-父工程
<!-- 构建和推动Docker镜像 -->
<plugin>
<groupId>com.spotify</groupId>
<artifactId>dockerfile-maven-plugin</artifactId>
<version>${docker.maven.plugin.version}</version>
<executions>
<execution>
<id>default</id>
<goals>
<!--如果package时不想用docker打包,就注释掉这个goal-->
<goal>build</goal>
<goal>push</goal>
</goals>
</execution>
</executions>
<configuration>
<contextDirectory>${project.basedir}</contextDirectory>
<useMavenSettingsForAuth>true</useMavenSettingsForAuth>
<repository>${docker.repository.url}/${docker.registry.name}/${project.artifactId}</repository>
<username>${docker.registry.username}</username>
<password>${docker.registry.password}</password>
<tag>${project.version}</tag>
<buildArgs>
<JAR_FILE>target/${project.build.finalName}.jar</JAR_FILE>
</buildArgs>
</configuration>
</plugin>
复制代码
配置信息
<!--Registry2仓库的地址,ip:port-->
<!--<docker.repository.url>192.168.172.128:5000</docker.repository.url>-->
<docker.repository.url>registry.cn-beijing.aliyuncs.com</docker.repository.url>
<!--上传的Docker镜像前缀,此前缀一定要和Harbor中的项目名称一致,和阿里云仓库的命名空间一致-->
<docker.registry.name>fly_jt</docker.registry.name>
<docker.registry.username>XXX@sina.com</docker.registry.username>
<docker.registry.password>XXX</docker.registry.password>
<docker.maven.plugin.version>1.4.13</docker.maven.plugin.version>
复制代码
Pom 配置-子工程
<plugin>
<groupId>com.spotify</groupId>
<artifactId>dockerfile-maven-plugin</artifactId>
<configuration>
<tag>${project.version}</tag>
</configuration>
</plugin>
复制代码
编写 Dockerfile 文件制作镜像
前提:
1. 要有环境变量 DOCKER_HOST 的配置
2. 要在子工程的目录下(与 pom 文件同级)创建一个 Dockerfile 文件
#设置镜像基础,jdk8
FROM java:8
#维护人员信息
MAINTAINER FLY
#设置镜像对外暴露端口
EXPOSE 8080
#将当前 target 目录下的 jar 放置在根目录下,命名为 app.jar,推荐使用绝对路径。
ADD target/devicemag-core-1.0.0.jar /devicemag-core-1.0.0.jar
#执行启动命令
ENTRYPOINT ["java", "-jar","/devicemag-core-1.0.0.jar"]
复制代码
在父工程 , 执行 mvn clean package 或者 mvn dockerfile:build 打包命令,即可制作镜像
docker images 查看镜像
[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
registry.cn-beijing.aliyuncs.com/fly_jt/devicemag-file 1.0.0 d09619501d27 11 seconds ago 643MB
registry.cn-beijing.aliyuncs.com/fly_jt/devicemag-system 1.0.0 9497ab784991 13 seconds ago 643MB
registry.cn-beijing.aliyuncs.com/fly_jt/devicemag-gateway 1.0.0 861d2577311b 16 seconds ago 643MB
registry.cn-beijing.aliyuncs.com/fly_jt/devicemag-auth 1.0.0 98ff94ed01d0 17 seconds ago 643MB
registry.cn-beijing.aliyuncs.com/fly_jt/devicemag-core 1.0.0 3defff63849a About a minute ago 643MB
mysql 5.7 a70d36bc331a 2 weeks ago 449MB
redis 5 e35748fd6a72 3 weeks ago 98.4MB
portainer/portainer-ce latest 980323c8eb3f 4 weeks ago 196MB
registry.cn-beijing.aliyuncs.com/fly_jt/portainer-ce 2.0.1 980323c8eb3f 4 weeks ago 196MB
registry 2 678dfa38fcfa 7 weeks ago 26.2MB
nacos/nacos-server 1.3.0 d1f1facebfbc 8 months ago 756MB
rabbitmq 3.7.15-management f05c3eb3cf91 19 months ago 179MB
java 8 d23bdf5b1b1b 4 years ago 643MB
[root@localhost ~]#
复制代码
推送镜像-Docker Registry
Docker Registry 2.0 搭建
docker run -d -v /opt/registry:/var/lib/registry -p 5000:5000 --restart=always --name registry2 registry:2
[root@localhost ~]# docker run -d -v /opt/registry:/var/lib/registry -p 5000:5000 --restart=always --name registry2 registry:2
cba73bc3417883d68d1d47c17e48bc62b0ca8705b1a2532be4f1f8c0f659db45
[root@localhost ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
cba73bc34178 registry:2 "/entrypoint.sh /etc…" 6 seconds ago Up 2 seconds 0.0.0.0:5000->5000/tcp, :::5000->5000/tcp registry2
复制代码
启动验证
1、列出所有镜像
# curl http://192.168.172.128:5000/v2/_catalog
2、查看指定镜像都有哪些 tag
# curl http://192.168.172.128:5000/v2/镜像名/tags/list
Docker Registry 用户和密码配置
容器运行成功,直接使用 docker login 192.168.172.128:5000 命令,输入 Username 和 Password
我这里设置的是
用户名: test 密码:test
用户和密码 base64
[root@localhost ~]# echo Hello World | base64^C
[root@localhost ~]# echo test:test | base64
dGVzdDp0ZXN0Cg==
[root@localhost ~]# echo dGVzdDp0ZXN0Cg== | base64 -d
test:test
复制代码
然后再 /.docker/config.json 添加如下内容{ "auths": { "192.168.172.128:5000": { "auth": "dGVzdDp0ZXN0" } }}
[root@localhost ~]# docker login 192.168.172.128:5000
Username: test
Password:
WARNING! Your password will be stored unencrypted in /root/.docker/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store
Login Succeeded
[root@localhost ~]# cat ~/.docker/config.json
{
"auths": {
"192.168.172.128:5000": {
"auth": "dGVzdDp0ZXN0"
}
}
}
复制代码
参考上面在父工程 Pom 中指定 repository 、username、password
推送镜像-阿里云
阿里云镜像仓库:拉取和推送Docker镜像
同时 参考上面在父工程 Pom 中指定 repository 、username、password
推送镜像-阿里云
在子工程 , 执行 mvn deploy 或者 mvn dockerfile:push 命令,即推送镜像
异常场景
1. com.spotify:dockerfile-maven-plugin:1.4.10 not found
在 Maven 配置文件 settings.xml 中添加
<pluginGroups>
<!-- pluginGroup
| Specifies a further group identifier to use for plugin lookup.
<pluginGroup>com.your.plugins</pluginGroup>
-->
<pluginGroup>com.spotify</pluginGroup>
</pluginGroups>
复制代码
2. java.io.FileNotFoundException: \\.\pipe\docker_engine (系统找不到指定的文件。)
[ERROR] Failed to execute goal com.spotify:dockerfile-maven-plugin:1.4.13:build (default) on project devicemag-core: Could not build image: java.util.concurrent.ExecutionException: com.spotify.docker.client.shaded.javax.ws.rs.ProcessingException: java.io.FileNotFoundException: \\.\pipe\docker_engine (系统找不到指定的文件。) -> [Help 1]
要使用服务器的 Docker 环境,需要配置一个环境变量(默认情况下,插件是连接本地的 Docker 环境,即 127.0.0.1)
环境变量的配置如下,改成你自己的服务器 Docker 环境即可(可能需要重启电脑):DOCKER_HOST tcp://192.168.1.6:2375
3. repository element was not specified in the POM inside distributionManagement element or in -DaltDeploymentRepository=id::layout::url parameter
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-deploy-plugin:2.7:deploy (default-deploy) on project devicemag-core: Deployment failed: repository element was not specified in the POM inside distributionManagement element or in -DaltDeploymentRepository=id::layout::url parameter -> [Help 1]
需要注意的是,如果你没有配置部署 artifact 的 maven repository,请不要使用 mvn deploy 命令,因为它会执行 maven-deploy-plugin 的 deploy 目标,而由于没有配置要部署的远程 maven repository,会报类似如上的错。
解决办法 1 :
在 pom.xml 中,应该将 distributionManagement 配置添加到要部署的位置。
<distributionManagement>
<repository>
<id>internal.repo</id>
<name>Internal repo</name>
<url></url>
</repository>
</distributionManagement>
复制代码
可以在部署期间使用以下命令添加另一个位置(但为了避免出现上述错误,应至少配置一个存储库):
解决办法 2 :
使用 mvn dockerfile:push 命令
评论