jenkins构建jar包为镜像并上传到docker仓库

简介: jenkins构建jar包为镜像并上传到docker仓库

01 引言

本文是一篇笔记,主要记录如下内容:

  • jenkins如何把maven项目构建为jar
  • jenkins然后把jar包构建为docker镜像
  • jenkins如何把docker镜像上传到仓库

下面来讲解一下相关的jenkins脚本。

02 jenkins打包maven项目

jenkins打包maven项目,其实就是在jenkins服务里面安装maven,然后使用maven命令来打包,命令如下:

mvn clean package -DeskipTests

03 jenkins构建jar包为镜像

3.1 确认编译系统状态

step1: 首先要确认编译系统的状态,命令如下:

docker buildx ls |grep builder0 | grep running || docker buildx inspect --bootstrap

3.2 清理构建缓存

然后清理docker构建缓存,命令如下:

docker buildx prune -a -f && docker builder prune -a -f;

3.3 构造Dockerfile

3.3.1 新建或下载Dockerfile模板

下载Dockerfile模板并输出到当前文件夹,文件名为:Dockerfile:

curl https://外网地址/Dockerfile.txt > Dockerfile

当然这里的Dockerfile模板是从服务器下载的,也可以放到jenkins服务器里面的一个目录,直接复制过来就可以了。

Dockerfile模板里面的内容为:

FROM ccr.ccs.tencentyun.com/xxx-base-img/jdk:11.0.11p9-20210917
ENV APP_VERSION __APP___VERSION__
WORKDIR /app
ADD https://xxx.cn/logback-spring.xml /app/
ADD https://xxx.cn/apm-agent.jar /app/
ADD https://xxx.cn/pre_exec.sh /app/
COPY __APP___JAR___PATH__ /app/
CMD mkdir -p /app/logs; \
if [ -d pre-exec-shells ];then for n in `ls pre-exec-shells/`;do bash pre-exec-shells/$n;done;fi;\
bash pre_exec.sh;\
mkdir -p /app/logs/${APP_VERSION}-${HOSTNAME}/heap_dump ;\
mkdir -p /app/logs/${APP_VERSION}-${HOSTNAME}/gc ;\
/usr/lib/jvm/java-11-openjdk-amd64/bin/java -server \
-Xmx${MEM_SIZE:-512}m -Xms16m \
-XX:MetaspaceSize=32m \
-XX:MaxMetaspaceSize=256m \
-XX:OnOutOfMemoryError="kill -9 %p" \
-XX:+UnlockExperimentalVMOptions -XX:+UseZGC \
-XX:+HeapDumpOnOutOfMemoryError \
-XX:HeapDumpPath=/app/logs/${APP_VERSION}-${HOSTNAME}/heap_dump/java_heapdump.hprof \
${EXT_JVM_CMD} \
-Dfile.encoding=UTF-8 \
-Xlog:gc*:file=/app/logs/${APP_VERSION}-${HOSTNAME}/gc/gc.log:time,tags:filecount=10,filesize=102400 \
${EXT_APM_CMD} \
-jar __APP___JAR___FILENAME__ \
--logging.file=/app/logs/${APP_VERSION}-${HOSTNAME}/ \
--spring.profiles.active=${SPRING_ACTIVE_PROFILE:-dev} \
--swagger.enable=false \
--logging.config=./logback-spring.xml \
${EXT_APP_CMD}

3.3.2 定义变量名

定义此变量为镜像的命名空间:

img_tag_name=项目/子项目名

定义此变量到对应jar包的相对地址,注意特殊符号要转义:

jar_path=项目\\\/target\\\/xxx.jar

定义此变量为对应jar包的文件名,注意要和jar_path对应的文件名一致

jar_name=xxx.jar

3.3.3 为Dockerfile变量赋值

ver_str=${Version}_`date "+%Y%m%d-%H%M%S"`
sed -i "s/__APP___VERSION__/$ver_str/" Dockerfile
sed -i "s/__APP___JAR___PATH__/$jar_path/" Dockerfile
sed -i "s/__APP___JAR___FILENAME__/$jar_name/" Dockerfile

3.4 打包镜像

打包脚本:

docker buildx prune -a -f && docker builder prune -a -f

4. 推送镜像到仓库

docker buildx build --platform linux/arm64,linux/amd64 --tag ccr.ccs.tencentyun.com/$img_tag_name:$ver_str --push . 
docker buildx prune -a -f && docker builder prune -a -f

5. Docker远程主机如何运行镜像

可以参考《Docker部署jar包运行》

目录
相关文章
|
2月前
|
人工智能 前端开发 Docker
从本地到云端:用 Docker Compose 与 Offload 构建可扩展 AI 智能体
在 AI 智能体开发中,开发者常面临本地调试与云端部署的矛盾。本文介绍如何通过 Docker Compose 与 Docker Offload 解决这一难题,实现从本地快速迭代到云端高效扩容的全流程。内容涵盖多服务协同、容器化配置、GPU 支持及实战案例,助你构建高效、一致的 AI 智能体开发环境。
331 1
从本地到云端:用 Docker Compose 与 Offload 构建可扩展 AI 智能体
|
2月前
|
缓存 安全 Linux
优化Docker镜像大小的多阶段构建实践
优化Docker镜像大小的多阶段构建实践
276 99
|
2月前
|
缓存 Docker 容器
优化Docker镜像大小的五个实用技巧
优化Docker镜像大小的五个实用技巧
287 98
|
1月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
336 5
|
2月前
|
Java Docker 容器
使用Docker多阶段构建优化镜像大小
使用Docker多阶段构建优化镜像大小
173 8
|
Java
[JarEditor]可直接修改jar包的IDEA插件
### 修改JAR包变得更简单:JarEditor插件简介 **背景:** 开发中常需修改JAR包中的class文件,传统方法耗时费力。JarEditor插件让你一键编辑JAR包内文件,无需解压。 **插件使用:** 1. **安装:** 在IDEA插件市场搜索JarEditor并安装。 2. **修改class:** 打开JAR文件中的class,直接编辑,保存后一键构建更新JAR。 3. **文件管理:** 右键菜单支持在JAR内新增/删除/重命名文件等操作。 4. **搜索:** 使用内置搜索功能快速定位JAR包内的字符串。
1582 2
[JarEditor]可直接修改jar包的IDEA插件
|
弹性计算 Java Serverless
Serverless 应用引擎操作报错合集之上传自定义JAR包,启动时报错,是什么导致的
Serverless 应用引擎(SAE)是阿里云提供的Serverless PaaS平台,支持Spring Cloud、Dubbo、HSF等主流微服务框架,简化应用的部署、运维和弹性伸缩。在使用SAE过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
关系型数据库 Java 分布式数据库
PolarDB产品使用问题之部署到服务器上的Java应用(以jar包形式运行)无法连接,如何解决
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
监控 Ubuntu Java
如何在Ubuntu上运行Jar包?
【7月更文挑战第9天】
1095 0
如何在Ubuntu上运行Jar包?

热门文章

最新文章