Java的jar包构建成docker镜像并运行
结构如下
把jar和Dockerfile放到一个文件,不在一个文件下会报错文件找不到
创建一个构建文件
buildimage.sh
vi /home/hanby/buildimage.sh
echo "运行创建镜像脚本"
docker build -t gateway:2.4.3 .
Dockerfile创建镜像
vi /home/hanby/Dockerfile
# 版本信息
#java:latest 为centos官方java运行环境镜像,600多M ,可以提前pull到主机本地
FROM java:latest
#MAINTAINER "指定作者或其他信息"
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
RUN mkdir -p /jeecg-cloud-gateway
WORKDIR /jeecg-cloud-gateway
#实际上可以配置成变量
ADD jeecg-cloud-gateway-2.4.3.jar /usr/local/jar/
RUN mv /usr/local/jar/jeecg-cloud-gateway-2.4.3.jar /usr/local/jar/gateway.jar
#开启内部服务端口 cicd-demo 项目端口
EXPOSE 9999
CMD ["java","-jar","/usr/local/jar/gateway.jar"]
run.sh 创建
vi /home/hanby/run.sh
echo "移除原本gateway镜像"
docker rm -f gateway
echo "运行新的gateway镜像,端口为9999"
#docker run --name="gateway" -p 9999:9999 -d gateway:2.4.3
docker run -d --restart=always --name gateway -v /home/jenkins-jar/buildgatewayImage/logs/:/logs/gateway/ -p 9999:9999 gateway:2.4.3
执行 ./buildgatewayImage.sh
./run-gateway-9999.sh
运行结果
出现的问题解决方法
如果用127.0.0.1访问docke启动的mysql,会报错,应该使用宿主机ip,或者在启动命令中添加--net=host,使容器和宿主机ip一致
如果出现宿主机和容器时间一致,但日志时间相差8小时,则在启动命令中添加如下:
-v /etc/timezone:/etc/timezone:ro \
-v /etc/localtime:/etc/localtime:ro \
用链接让容器使用系统时区
如果是springboot项目,也可以在启动类添加
TimeZone.setDefault(TimeZone.getTimeZone("Asia/Shanghai"));
然而jar的大小总的来说还是很大,所有使用瘦身打包,可以把每个jar分离为依赖组件lib目录和一个业务jar来进行部署,优化单个jar文件大小到一两百KB。
但是对于很多个微服务,每个服务一个jar和一个lib目录文件,首次部署也差不多需要传输一两个GB文件。
所以合并所有模块依赖jar到同一个lib目录,一般由于各模块项目依赖jar重叠程度很高,合并所有服务部署文件总计大小基本也就两三百MB
启动过程不再需要 -Djava.ext.dirs=lib 参数定义,所有微服务jar引用所有项目合并依赖组件的公共目录,部署文件总计大小一般在两三百MB,通过定制每个微服务jar文件中的META-INFO/MANIFEST文件中的Class-Path明确指明依赖版本组件类,解决各微服务不同组件版本冲突问题。
微服务配置,可以给父pom配置,如果其中有不需要瘦身打包的,则需要单独配置每一个需要瘦身打包的服务,也可以排除不需要瘦身打包,怎样方便怎样来
父pom配置
<build>
<finalName>${project.artifactId}</finalName>
<!--
特别注意:
项目仅仅是为了演示配置方便,直接在parent的build部分做了插件配置和运行定义。
但是实际项目中需要把这些定义只放到spring boot模块项目(可优化使用pluginManagement形式),避免干扰其他util、common等模块项目
-->
<plugins>
<!-- 基于maven-jar-plugin插件实现把依赖jar定义写入输出jar的META-INFO/MANIFEST文件 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<classpathPrefix>lib/</classpathPrefix>
<useUniqueVersions>false</useUniqueVersions>
</manifest>
</archive>
</configuration>
</plugin>
<!-- 拷贝项目所有依赖jar文件到构建lib目录下 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-dependency-plugin</artifactId>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>package</phase>
<goals>
<goal>copy-dependencies</goal>
</goals>
<configuration>
<!--
各子模块按照实际层级定义各模块对应的属性值,检查所有微服务模块依赖jar文件合并复制到同一个目录
详见各子模块中 boot-jar-output 属性定义
-->
<outputDirectory>${boot-jar-output}/lib</outputDirectory>
<excludeTransitive>false</excludeTransitive>
<stripVersion>false</stripVersion>
<silent>false</silent>
</configuration>
</execution>
</executions>
</plugin>
<!-- Spring Boot模块jar构建 -->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<includes>
<!-- 不存在的include引用,相当于排除所有maven依赖jar,没有任何三方jar文件打入输出jar -->
<include>
<groupId>null</groupId>
<artifactId>null</artifactId>
</include>
</includes>
<layout>ZIP</layout>
<!--
基于maven-jar-plugin输出微服务jar文件进行二次spring boot重新打包文件的输出目录
所有微服务构建输出jar文件统一输出到与lib同一个目录,便于共同引用同一个lib目录
详见各子模块中boot-jar-output属性定义
-->
<outputDirectory>${boot-jar-output}</outputDirectory>
</configuration>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
<!--###################瘦身打包######################################-->
子pom配置
<!--###########瘦身打包###########文件路径自己定义即可-->
<properties>
<java.version>8</java.version>
<boot-jar-output>../toImageJar</boot-jar-output>
</properties>
打包结果如下
docker 配置
Dockerfile 修改
# 版本信息
#java:latest 为centos官方java运行环境镜像,600多M ,可以提前pull到主机本地
FROM java:latest
#MAINTAINER "指定作者或其他信息"
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
#RUN mkdir -p /jeecg-cloud-pay
#在jar文件目录下创建一个lib
RUN mkdir -p /usr/local/jar/lib
#WORKDIR /jeecg-cloud-pay
#实际上可以配置成变量
ADD jeecg-cloud-flh-pay.jar /usr/local/jar/
#COPY lib /usr/local/jar/lib
RUN mv /usr/local/jar/jeecg-cloud-flh-pay.jar /usr/local/jar/pay.jar
#开启内部服务端口 pay项目端口
EXPOSE 7006
CMD ["java","-Xms1024m","-Xmx1024m","-jar","/usr/local/jar/pay.jar"]
run-pay-7006.sh 配置
echo "移除原本pay镜像"
docker rm -f pay
echo "运行新的pay镜像"
docker run -d --restart=always --name pay \
--net=host \
-v /etc/timezone:/etc/timezone:ro \
-v /etc/localtime:/etc/localtime:ro \
-v /data/soft/imageAPP/logs/pay/:/logs/pay/ \
-v /data/soft/imageAPP/lib:/usr/local/jar/lib \ 映射目录,如此就只需要一个lib即可,也可以copy lib到容器(麻烦,必须在每个容器里面复制一份)
-p 7006:7006 pay:2.4.3
其他打包方式参考 https://mp.weixin.qq.com/s/hstk9tXzKt-Up20kD5x0fg
Java的jar包构建成docker镜像并运行的更多相关文章
- 将jar包制作成docker镜像
将jar包制作成docker镜像1.准备可运行jar包2.建立Dockerfile文件 文件内容: FROM java:8VOLUME /tmpADD xxx-sendemail-0.0.1-SNAP ...
- 把java(springboot)程序打包docker镜像
前言:要在docker运行java(jar包)程序,就要把程序打包成docker镜像(以下简称镜像),可以先理解为镜像就是jar包 打包需要程序代码,java本身的打包环境(包括jdk和maven), ...
- java 执行 jar 包中的 main 方法
java 执行 jar 包中的 main 方法 通过 OneJar 或 Maven 打包后 jar 文件,用命令: java -jar ****.jar执行后总是运行指定的主方法,如果 jar 中有多 ...
- Java常用jar包用途
Java常用jar包用途: USAGE INDEX JAR NAME USAGE 1 ASM asm-2.2.3.jar ASM字节码库 2 ASM asm-commons-2.2.3.jar ASM ...
- (转)java 从jar包中读取资源文件
(转)java 从jar包中读取资源文件 博客分类: java 源自:http://blog.csdn.net/b_h_l/article/details/7767829 在代码中读取一些资源文件 ...
- Python3.5调用Java的jar包
声明:这个是在一个博客上看到的,过了俩星期了突然找不到原博客了,如果原来的博主看到,请联系我删除~ 主要是怕自己忘记,所以在此记录: 环境 Python3.5+JDK1.8 安装命令:python3 ...
- Java axis2.jar包详解及缺少jar包错误分析
Java axis2.jar包详解及缺少jar包错误分析 一.最小开发jar集 axis2 开发最小jar包集: activation-1.1.jar axiom-api-1.2.13.jar ax ...
- java执行jar包出错:Unable to access jarfile
java执行jar包出错:Unable to access jarfile 错误的原因有多种: 1.一般都是路径不正确.在Windows中,正确的路径类似于: java -jar "D:\W ...
- java 生成jar包并保留注释
java 生成jar包并保留注释 CreationTime--2018年7月17日08点32分 Author:Marydon 1.选中java项目-->右键-->Export: 2.去 ...
随机推荐
- 错误: 找不到或无法加载主类(IDEA中启动spring boot项目)
版权声明:本文为博主原创文章,如果转载请给出原文链接:http://www.jufanshare.com/content/142.html 提示:需要对IDEA编辑工具使用熟悉 出现一个问题,就是sp ...
- 使用Spring JDBC连接数据库(以SQL Server为例)
一.配置Spring JDBC 1.导入相关jar包 (略) 2.配置文件applicationContext.xml <?xml version="1.0" encodin ...
- JSP页面的基本结构
一:一个JSP页面由以下基本元素组成. (1)HTML标签 (2)CSS (3)变量和方法 (4)Java代码段 (5)JSP动作和指令 (6)其他脚本元素(如Javascript) 二:JSP的基本 ...
- 如何简单的理解LSTM——其实没有那么复杂(转载)
转载地址:https://www.jianshu.com/p/4b4701beba92 1.循环神经网络 人类针对每个问题的思考,一般不会是完全的从头开始思考.正如当你阅读这篇译文的时候,你会根据已经 ...
- 全网最详细的AbstractQueuedSynchronizer(AQS)源码剖析(二)资源的获取和释放
上期的<全网最详细的AbstractQueuedSynchronizer(AQS)源码剖析(一)AQS基础>中介绍了什么是AQS,以及AQS的基本结构.有了这些概念做铺垫之后,我们就可以正 ...
- 软件开发生命周期(SDLC)
一.简介 软件开发生命周期又叫做 SDLC(Software Development Life Cycle),它是集合了计划.开发.测试和部署过程的集合.如下图所示 : 二.五个阶段 1.分析阶段: ...
- zctf_2016_note3(unlink)
这道题完全没想到漏洞在哪(还是菜了) 这道题目我通过海哥的博客学习的 (16条消息) zctf_2016_note3_seaaseesa的博客-CSDN博客 例行检查我就不放了 进入edit页面 这里 ...
- [BUUCTF]PWN——ciscn_2019_es_7[详解]
ciscn_2019_es_7 附件 步骤: 例行检查,64位程序,开启了nx保护 本地试运行一下看看大概的情况 64位ida载入,关键函数很简单,两个系统调用,buf存在溢出 看到系统调用和溢出,想 ...
- c++模板类的使用,编译的问题
1,模板类编译的问题 前两天在写代码时,把模板类的声明和分开放在两个文件中了,类似于下面这样: stack.hpp: #ifndef _STACK_HPP #define _STACK_HPP tem ...
- AT2686 [ARC080A] 4-adjacent 题解
Content 给定一个长度为 \(n\) 的数列 \(a\),请将其重新排列,使得 \(\forall i\in[1,n-1]\),都有 \(4\mid (a_i\cdot a_{i+1})\),或 ...