环境准备: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. HDU 6470 【矩阵快速幂】

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6470 写这道题是为了让自己不要忘记矩阵快速幂如何推出矩阵式子的. 注意 代码是TLE的!! #incl ...

  2. vue中使用第三方插件animate.css实现动画效果

    vue中使用第三方插件animate.css实现动画效果1.首先先引入第三方类animated.css2.将你所需要动画的标签用包裹起来3.在transition元素中添加enter-active-c ...

  3. mingw-w64 gcc std::thread 行为异常

    我用的 ming-w64 gcc 是通过 MSYS2 安装的,包名是 mingw-w64-x86_64-gcc,版本 9.2.0-2. 我发现 std::thread 行为异常. int main() ...

  4. java http接口请求响应 request response

    接口类: 1 package org.sunshine.dcda.epg.wechat.controller.niao; 2 3 import javax.servlet.http.HttpServl ...

  5. Scala当中什么是Transformation和 Action,以及它们俩的区别是什么?

    [学习笔记] 一个完整的RDD任务由两部分组成:Transformation和 Action.Transformation用于对RDD的创建,还可以把老的RDD通过Transformation来生成新 ...

  6. 序列化,os,sys,hashlib,collections

    序列化,os,sys,hashlib,collections 1.序列化 什么是序列化?序列化的本质就是将一种数据结构(如字典,列表)等转换成一个特殊的序列(字符串或者bytes)的过程就叫做序列化. ...

  7. oracle多表关联删除的两种方法

    oracle多表关联删除的两种方法 第一种使用exists方法 delete from tableA where exits ( select 1 from tableB Where tableA.i ...

  8. 安装 Dashboard 插件

    Kubernetes Dashboard 是 k8s集群的一个 WEB UI管理工具,代码托管在 github 上,地址:https://github.com/kubernetes/dashboard ...

  9. java8【一、lambda表达式语法】

    特点 lambda表达式允许将函数作为方法的参数 lambda表达式更加简洁 特征 可选类型声明:不需要声明参数类型,编译器可以统一识别参数值. 可选的参数圆括号:一个参数无需定义圆括号,但多个参数需 ...

  10. LeetCode 866. Prime Palindrome

    866. Prime Palindrome(回文素数) 题目: 求出大于或等于 N 的最小回文素数. 回顾一下,如果一个数大于 1,且其因数只有 1 和它自身,那么这个数是素数. 例如,2,3,5,7 ...