一、导入docker maven插件java
<!-- 生成时间戳 -->
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>build-helper-maven-plugin</artifactId>
<version>1.9.1</version>
<executions>
<execution>
<id>timestamp-property</id>
<goals>
<goal>timestamp-property</goal>
</goals>
</execution>
</executions>
<configuration>
<name>current.time</name>
<pattern>yyyyMMddHHmmss</pattern>
<timeZone>GMT+8</timeZone>
</configuration>
</plugin>docker
<!-- 打包生成镜像、push镜像到私有镜像中心 -->
<plugin>
<groupId>com.spotify</groupId>
<artifactId>dockerfile-maven-plugin</artifactId>
<version>1.4.0</version>
<executions>
<execution>
<id>default</id><!-- 要绑定到的生命周期的阶段 -->
<phase>install</phase><!-- 要绑定到的生命周期的阶段 -->
<goals> <!-- 要绑定的插件的目标 -->
<goal>build</goal>
<goal>push</goal>
</goals>
</execution>
</executions>
<configuration>
<!-- 私有镜像中心的用户名 -->
<username>registry</username>
<!-- 私有镜像中心的密码 -->
<password>******</password>
<!-- 172.16.1.146:私有镜像中心地址; wondertek/${project.artifactId}:镜像名称-->
<repository>172.16.1.146/wondertek/${project.artifactId}</repository>
<!-- 镜像版本号 -->
<tag>${project.version}-${current.time}</tag>shell
文章标题app
文章分类maven
<buildArgs>
<!-- 参数,提供给dockerfile使用 -->
<JAR_FILE>target/docker-test-1.0.0.jar</JAR_FILE>
</buildArgs>ui
# 拉取基础镜像
FROM hub.c.163.com/library/java:8-jdk
# 镜像的做者
MAINTAINER csp@xxx.comspa
#挂载目录,经过 VOLUME 指令建立的挂载点,没法指定主机上对应的目录,是自动生成的
VOLUME ["/data1","/data2"]插件
RUN ["mkdir", "-p", "/app"]code
#结合maven插件dockerfile-maven-plugin的打包使用
ARG JAR_FILE
ADD ${JAR_FILE} /app/app.jar生命周期
#为后面的 RUN, CMD, ENTRYPOINT, ADD 或 COPY 指令设置镜像中的当前工做目录。
#WORKDIR /usr/local/docker/test
#拷贝当前目录文件到容器/app
#COPY . /app
#与 COPY 相似,从 build context 复制文件到镜像。不一样的是,若是 src 是归档文件(tar, zip, tgz, xz 等),文件会被自动解压到 dest。
#ADD src dest
#设置环境变量,环境变量可被后面的指令使用
ENV EVN_SET_TEST "WELCOME TO DOCKERFILE CONTAINER!"
##################
# RUN、CDM、ENTRYPOINT 命令都包含两种格式:Shell 格式和 Exec 格式
# CMD还能够放在ENTRYPOINT后,为其传递参数。
##### shell 格式:######
## 底层会调用 /bin/sh -c <command>
# 在容器中运行指定的命令
RUN echo $EVN_SET_TEST
# 容器启动命令 只有最后一个生效,CMD 能够被 docker run 以后的参数替换。
#只有最后一个生效
CMD echo "CMD Hello world"
#配置容器启动时运行的命令
ENTRYPOINT echo "ENTRYPOINT Hello, $EVN_SET_TEST"
###### Exec 格式: #####
## 当指令执行时,会直接调用 <command>,不会被 shell 解析
# ENTRYPOINT ["/bin/echo", "Hello, $EVN_SET_TEST"]
# 正确写法应该为:
# ENTRYPOINT ["/bin/sh", "-c", "echo Hello, $EVN_SET_TEST"]
# 为Exec 格式的ENTRYPOINT传递参数,结果输出Hello, $EVN_SET_TEST dockerfile world
# CMD ["dockerfile world"]
#只有最后一个生效
ENTRYPOINT ["java","-jar","/app/app.jar"]
#表示哪一个端口提供服务的提示,宿主机若是要访问,须要结合-P参数联合使用。
EXPOSE 8080
build镜像: mvn clean package dockerfile:build -DskipTests
发布镜像不会编译:mvn dockerfile:push
编译发布: mvn clean install -Ddockerfile.skip
命令 说明 dockerfile.skip Disables the entire dockerfile plugin; all goals become no-ops. dockerfile.build.skip Disables the build goal; it becomes a no-op. dockerfile.tag.skip Disables the tag goal; it becomes a no-op. dockerfile.push.skip Disables the push goal; it becomes a no-op.