环境准备:win10+docker
1.打开hyper-v
3.切换到docker的linux环境:右键桌面右下角小船图标
4.暴露2375端口
 
用户认证信息配置:
<configuration>
<repository>docker-repo.example.com:8080/organization/image</repository>
<tag>latest</tag>
<useMavenSettingsForAuth>true</useMavenSettingsForAuth>
</configuration>

setting.xml添加远程仓库信息

<servers>
<server>
<id>docker-repo.example.com:8080</id>
<username>me</username>
<password>mypassword</password>
</server>
</servers>

pom.xml配置

<plugin>
<groupId>com.spotify</groupId>
<artifactId>dockerfile-maven-plugin</artifactId>
<version>1.4.4</version>
<executions>
<execution>
<id>default</id>
<goals>
<goal>build</goal>
<goal>push</goal>
</goals>
</execution>
</executions>
<dependencies>
<dependency>
<groupId>javax.activation</groupId>
<artifactId>activation</artifactId>
<version>1.1.1</version>
</dependency>
</dependencies>
<configuration>
//上下文路径配置,此处设置为项目根路径
<contextDirectory>${project.basedir}</contextDirectory>
<useMavenSettingsForAuth>true</useMavenSettingsForAuth>
<repository>${registryUrl}/hush/${project.build.finalName}</repository>
<tag>${imageVersion}</tag>
//作为Dockerfile文件传入
<buildArgs>
<JAR_FILE>${project.build.finalName}.jar</JAR_FILE>
</buildArgs>
</configuration>
</plugin>

Dockerfile文件编写(放置在项目根路径)

FROM registry.cn-hangzhou.aliyuncs.com/hush/basecontainer:20180929

#添加本地jar包
RUN mkdir -p /home/admin/app/
RUN mkdir -p /home/admin/tomcat/
ENV CATALINA_HOME /home/admin/tomcat/
#
ARG JAR_FILE ADD target/${JAR_FILE} /home/admin/app/
#
#
#
# 将启动命令写入启动脚本 start.sh
RUN echo "$JAVA_HOME/bin/java -jar $JAVA_OPTS -Ddubbo.address.ip=$POD_IP -Djava.security.egd=file:/dev/./urandom /home/admin/app/${JAR_FILE} --spring.profiles.active=prod" > /home/admin/start.sh && chmod +x /home/admin/start.sh
WORKDIR $CATALINA_HOME
ENTRYPOINT ["/bin/bash", "/home/admin/start.sh"]

打包镜像:

[INFO] Scanning for projects...
[INFO]
[INFO] -----------------------< org.hush.k8s:provider >------------------------
[INFO] Building provider 0.0.1-SNAPSHOT
[INFO] --------------------------------[ jar ]---------------------------------
[INFO]
[INFO] --- dockerfile-maven-plugin:1.4.4:build (default-cli) @ provider ---
[INFO] Building Docker context D:\2018\my_pro\demo\provider
[INFO]
[INFO] Image will be built as registry.cn-hangzhou.aliyuncs.com/hush/dubbo_provider:1.0.4
[INFO]
[INFO] Step 1/9 : FROM registry.cn-hangzhou.aliyuncs.com/hush/basecontainer:20180929
[INFO]
[INFO] Pulling from hush/basecontainer
[INFO] Digest: sha256:35cdf59cd63e8f47cbb5ab595ad327f6ff2df8b910e34d958f83b942d072b713
[INFO] Status: Image is up to date for registry.cn-hangzhou.aliyuncs.com/hush/basecontainer:20180929
[INFO] ---> a8440ec1b0aa
[INFO] Step 2/9 : RUN mkdir -p /home/admin/app/
[INFO]
[INFO] ---> Using cache
[INFO] ---> c88518200882
[INFO] Step 3/9 : RUN mkdir -p /home/admin/tomcat/
[INFO]
[INFO] ---> Using cache
[INFO] ---> 0f9dceff2421
[INFO] Step 4/9 : ENV CATALINA_HOME /home/admin/tomcat/
[INFO]
[INFO] ---> Using cache
[INFO] ---> 0c8108c0b64e
[INFO] Step 5/9 : ARG JAR_FILE
[INFO]
[INFO] ---> Using cache
[INFO] ---> 5df43a413985
[INFO] Step 6/9 : ADD target/${JAR_FILE} /home/admin/app/
[INFO]
[INFO] ---> Using cache
[INFO] ---> 5763c04c6c27
[INFO] Step 7/9 : RUN echo '$JAVA_HOME/bin/java -jar $JAVA_OPTS -Ddubbo.address.ip=$POD_IP -Djava.security.egd=file:/dev/./urandom "/home/admin/app/dubbo_provider.jar" --spring.profiles.active=prod' > /home/admin/start.sh && chmod +x /home/admin/start.sh
[INFO]
[INFO] ---> Using cache
[INFO] ---> 2789f23853b2
[INFO] Step 8/9 : WORKDIR $CATALINA_HOME
[INFO]
[INFO] ---> Using cache
[INFO] ---> b87c1ad13e7d
[INFO] Step 9/9 : ENTRYPOINT ["/bin/bash", "/home/admin/start.sh"]
[INFO]
[INFO] ---> Using cache
[INFO] ---> 5debdfca2614
[INFO] Successfully built 5debdfca2614
[INFO] Successfully tagged registry.cn-hangzhou.aliyuncs.com/hush/dubbo_provider:1.0.4
[INFO]
[INFO] Detected build of image with id 5debdfca2614
[INFO] Building jar: D:\2018\my_pro\demo\provider\target\dubbo_provider-docker-info.jar
[INFO] Successfully built registry.cn-hangzhou.aliyuncs.com/hush/dubbo_provider:1.0.4
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 8.552 s
[INFO] Finished at: 2018-10-01T11:45:37+08:00
[INFO] ------------------------------------------------------------------------

在容器上可以执行docker images|grep <相应镜像名称>

docker push:

[INFO] Scanning for projects...
[INFO]
[INFO] -----------------------< org.hush.k8s:provider >------------------------
[INFO] Building provider 0.0.1-SNAPSHOT
[INFO] --------------------------------[ jar ]---------------------------------
[INFO]
[INFO] --- dockerfile-maven-plugin:1.4.4:build (default-cli) @ provider ---
[INFO] Building Docker context D:\2018\my_pro\demo\provider
[INFO]
[INFO] Image will be built as registry.cn-hangzhou.aliyuncs.com/hush/dubbo_provider:1.0.4
[INFO]
[INFO] Step 1/9 : FROM registry.cn-hangzhou.aliyuncs.com/hush/basecontainer:20180929
[INFO]
[INFO] Pulling from hush/basecontainer
[INFO] Digest: sha256:35cdf59cd63e8f47cbb5ab595ad327f6ff2df8b910e34d958f83b942d072b713
[INFO] Status: Image is up to date for registry.cn-hangzhou.aliyuncs.com/hush/basecontainer:20180929
[INFO] ---> a8440ec1b0aa
[INFO] Step 2/9 : RUN mkdir -p /home/admin/app/
[INFO]
[INFO] ---> Using cache
[INFO] ---> c88518200882
[INFO] Step 3/9 : RUN mkdir -p /home/admin/tomcat/
[INFO]
[INFO] ---> Using cache
[INFO] ---> 0f9dceff2421
[INFO] Step 4/9 : ENV CATALINA_HOME /home/admin/tomcat/
[INFO]
[INFO] ---> Using cache
[INFO] ---> 0c8108c0b64e
[INFO] Step 5/9 : ARG JAR_FILE
[INFO]
[INFO] ---> Using cache
[INFO] ---> 5df43a413985
[INFO] Step 6/9 : ADD target/${JAR_FILE} /home/admin/app/
[INFO]
[INFO] ---> Using cache
[INFO] ---> 5763c04c6c27
[INFO] Step 7/9 : RUN echo '$JAVA_HOME/bin/java -jar $JAVA_OPTS -Ddubbo.address.ip=$POD_IP -Djava.security.egd=file:/dev/./urandom "/home/admin/app/dubbo_provider.jar" --spring.profiles.active=prod' > /home/admin/start.sh && chmod +x /home/admin/start.sh
[INFO]
[INFO] ---> Using cache
[INFO] ---> 2789f23853b2
[INFO] Step 8/9 : WORKDIR $CATALINA_HOME
[INFO]
[INFO] ---> Using cache
[INFO] ---> b87c1ad13e7d
[INFO] Step 9/9 : ENTRYPOINT ["/bin/bash", "/home/admin/start.sh"]
[INFO]
[INFO] ---> Using cache
[INFO] ---> 5debdfca2614
[INFO] Successfully built 5debdfca2614
[INFO] Successfully tagged registry.cn-hangzhou.aliyuncs.com/hush/dubbo_provider:1.0.4
[INFO]
[INFO] Detected build of image with id 5debdfca2614
[INFO] Building jar: D:\2018\my_pro\demo\provider\target\dubbo_provider-docker-info.jar
[INFO] Successfully built registry.cn-hangzhou.aliyuncs.com/hush/dubbo_provider:1.0.4
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 8.552 s
[INFO] Finished at: 2018-10-01T11:45:37+08:00
[INFO] ------------------------------------------------------------------------

在镜像仓库可以直接查看

  

  

dockerfile-maven plugin自动镜像制作并发布的更多相关文章

  1. Docker系列-(2) 镜像制作与发布

    上篇文章引入了Docker的基本原理和操作,本节文章主要介绍如何制作Docker镜像和发布. 镜像文件结构 Docker镜像的本质是一系列文件的集合,这些文件依次叠加,形成了最后的镜像文件,类似于下图 ...

  2. docker镜像制作及发布

    以centos为例. 主要内容:安装docker,制作镜像,发布镜像. 安装docker 1. 安装docker yum install -y docker 等待一会,安装成功,查看安装列表 2. 启 ...

  3. Docker教程:镜像构建和自动镜像构建dockerfile

    http://blog.csdn.net/pipisorry/article/details/50805379 Docker透过Dockerfile来记录建立Container映象文件的每一个步骤,可 ...

  4. 基于Dockerfile镜像制作的基本操作

    一.使用Dockerfile制作镜像 前面的博客中已经介绍了如何基于容器制作镜像,此方法的原理是使用一个正在运行的容器,根据生产所需进行配置更改等操作后,使其满足生产环境,再将这个容器打包制作为镜像, ...

  5. 测试环境docker化(一)—基于ndp部署模式的docker基础镜像制作

    本文来自网易云社区 作者:孙婷婷 背景 我所在测试项目组目前的测试环境只有一套,在项目版本迭代过程中,开发或产品偶尔会在测试环境进行数据校验,QA人数在不断增加,各个人员在负责不同模块工作时也会产生脏 ...

  6. MySQL、MongoDB、Redis数据库Docker镜像制作

    MySQL.MongoDB.Redis数据库Docker镜像制作 在多台主机上进行数据库部署时,如果使用传统的MySQL的交互式的安装方式将会重复很多遍.如果做成镜像,那么我们只需要make once ...

  7. openstack私有云布署实践【16.3 Windows Server2008 R2 只有C盘分区镜像制作】

    之所以要只有C盘分区镜像,是因为在创建VM或者调整云主机的硬盘大小时,它能自动扩容.无需人工介入   参考http://www.iyunv.com/thread-45149-1-1.html的灵感   ...

  8. Spring Boot Maven Plugin(一):repackage目标

    简介 Spring Boot Maven Plugin插件提供spring boot在maven中的支持.允许你打包可运行的jar包或war包. 插件提供了几个maven目标和Spring Boot ...

  9. Docker镜像管理基础与基于容器的镜像制作示例

    一.Docker镜像 Docker镜像是启动Docker容器的一个非常重要的组件.Docker各组件之间的关系如图: Docker镜像含有启动容器所需要的文件系统及其内容,因此Docker镜像用于创建 ...

随机推荐

  1. 33.TCP协议概念/scapy模块doos攻击

    TCP协议概念/scapy模块: 1,TCP/IP四层协议: 2,TCP数据包的构成: TCP FLAGS:TCP数据包标志位 U:URG,紧急比特 A:ACK,确认比特 P:PSH,推送比特 S:S ...

  2. 冲刺Noip2017模拟赛2 解题报告——五十岚芒果酱

    题1 牛跑步(running) [题目描述] 新牛到部队,CG 要求它们每天早上搞晨跑,从 A 农场跑到 B 农场.从 A 农场到 B 农场中有 n- 个路口,分别标上号,A 农场为 号,B 农场为 ...

  3. linux下jenkins的安装

    构建伟大,无所不能 Jenkins是开源CI&CD软件领导者, 提供超过1000个插件来支持构建.部署.自动化, 满足任何项目的需要. 参考博客:https://www.cnblogs.com ...

  4. shell top

    top -bn1 它表示非动态打印系统资源使用情况,即一次性全部把所有信息输出出来而非动态显示,可以用在shell脚本中

  5. [转帖]IBM开源Power指令集:国产高性能CPU迎来新机遇?

    IBM开源Power指令集:国产高性能CPU迎来新机遇? https://www.cnbeta.com/articles/tech/880971.htm cnbeta的新闻.. 希望高性能CPU 能快 ...

  6. HDU 1325 有根树的判断

    Is It A Tree? Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total ...

  7. C - Co-prime

    Given a number N, you are asked to count the number of integers between A and B inclusive which are ...

  8. HeidiSQL 导入Excel数据

    一 前言 原文出处:http://blog.csdn.net/qq_27727681/article/details/53944744 二 效果演示: 2000多条数据,顺利导入成功. 三  实现方法 ...

  9. 数据库(mysql和oracle)

    1.   mysql索引:    https://www.jikewenku.com/22030.html 2.

  10. Java多线程(八):ReentrantReadWriteLock

    读写锁ReentrantReadWriteLock概述 读写锁ReentrantReadWriteLock,使用它比ReentrantLock效率更高. 读写锁表示两个锁,一个是读操作相关的锁,称为共 ...