流水线用到的Dockerfile和构建脚本build.sh

接着 上一篇文章调用的脚本

流水线通用脚本-shell形式,直接改几个参数,可以拿到Jenkins,github和 gitee和 gitlab等直接调用(主要是Jenkins,改的参数比较少)-CSDN博客

上一篇进榜了嘻嘻

root@jenkins dev-build# cat Dockerfile

###Dockerfile(多阶段构建)

##注意合并指令减少层数

#运行时环境(轻量级使用最小镜像)

##docker.io/library/alpine:latest

##Alpine是一个轻量级的Linux发行版只需要约5MB

##使用国内镜像站下载

#docker pull swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/library/alpine:latest

#crictl images pull swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/library/alpine:latest

###jdk17镜像

设置环境变量(单层)

##471.47MB

#docker pull swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/openjdk:17.0.2-jdk

#crictl images swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/openjdk:17.0.2-jdk

##17-jdk-alpine 325.60MB

#docker pull

#crictl images

#swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/openjdk:17-jdk-alpine

#docker pull

##crictl images

#openjdk:17-jre-slim比 JDK 镜像体积小 60% 以上

#我那个openjdk:17-jre-slim有漏洞这个废弃

#FROM openjdk:17-jdk-slim

##alpine镜像比默认 openjdk体积小 70%+,且减少隐式系统层

#使用镜像站镜像

FROM swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/openjdk:17-jdk-alpine

#使用harbor镜像仓库镜像

#xxxx

#docker.io/library/buildpack-deps

#这是一个包含构建依赖项的Docker镜像。

#它提供各种构建工具和运行库,用于构建不同的应用程序,

#特别是那些使用构建包工具(例如Paketo Buildpacks)的应用程序。

这个镜像本身并不包含应用程序代码,

而是为构建过程提供必要的依赖环境,

从而简化构建过程和镜像大小

swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/library/buildpack-deps:jammy

#buildpack-deps 上面这个是ubuntu:

##docker pull

##crictl images

设置环境变量(单层)

ENV JAVA_OPTS="-Xms512m -Xmx1024m" \

SPRING_PROFILES_ACTIVE="prod" \

SERVER_PORT=8080

复制 Spring Boot 的可执行ja)(已经包含了所有子模块代码和依赖)

复制构建产物(分离依赖与代码以利用缓存)注入环境变量

ARG ENV_FILE=./env/dev.env

#复制之前打包生成的jar包到指定位置 # 复制环境文件到容器中(使用构建参数 &&# 复制启动脚本

COPY payment-api/target/payment-api-0.0.1-SNAPSHOT.jar app.jar &&COPY ${ENV_FILE} .env &&COPY build/start.sh start.sh

创建用户并设置权限(单层完成所有权限操作)

RUN addgroup -S javauser && adduser -S javauser -G javauser \

&& chown -R javauser:javauser /app \

&& chmod +x start.sh

切换用户

USER javauser

健康检查(单层)

HEALTHCHECK --interval=30s --timeout=3s --start-period=60s --retries=3 \

CMD curl -f http://localhost:${SERVER_PORT}/actuator/health || exit 1

入口点

ENTRYPOINT "./start.sh"

EXPOSE 8080

root@jenkins dev-build# cat build.sh

#!/bin/bash

定义源目录和目标目录

SOURCE_DIR="/home/$repo/java/payment"

TARGET_DIR="$(pwd)/app"

IMAGE_NAME="$镜像仓库域名/命名空间/wallet-test"

DEFAULT_VERSION="s01" # 是jenkins传递的版本号s01 是v构建次数-时间日期方便从 举例v177-20250827-1800

设置基础变量

export LANG=zh_CN.UTF-8

export PATH=/opt/maven-3.9.11/bin:/usr/lib/jvm/jdk-17.0.16-oracle-x64/bin:$PATH

检查参数

if -z "$1" ; then

echo "使用方法: ./build.sh 环境 版本"

echo "支持的环境: dev, uat, prd"

echo ""

echo "示例:"

echo " ./build.sh uat"

echo " ./build.sh prd v1.0.0"

echo " ./build.sh dev"

exit 1

fi

ENV_NAME=$1

VERSION=$DEFAULT_VERSION

验证环境参数

case $ENV_NAME in

"dev")

ENV_FILE=./env/dev.env

IMAGE_TAG=IMAGE_NAME:VERSION

;;

"uat")

ENV_FILE=./tmp/huoma-dzg/server/service/pay-of-java/env/

IMAGE_TAG=IMAGE_NAME:VERSION

;;

"prd")

ENV_FILE=./tmp/huoma-dzg/server/service/pay-of-java/env

IMAGE_TAG=IMAGE_NAME:VERSION

;;

*)

echo "ERROR 不支持的环境: $ENV_NAME"

echo "支持的环境: dev, uat, prd"

exit 1

;;

esac

#调试输出

echo "INFO 构建环境: $ENV_NAME"

#echo "INFO 环境文件: $ENV_FILE"

#echo "INFO 镜像+标签: $IMAGE_TAG"

1.Maven检查并构建

检查 Maven 是否安装

if ! command -v mvn &> /dev/null; then

echo "ERROR Maven 未安装或不在 PATH 中"

exit 1

fi

###这个需要自己进行选择切换的目录根据java环境不同进行切换对应项目下

cd ../

mvn clean install -DskipTests

if $? -ne 0 ; then

echo "ERROR Maven 构建失败!"

exit 1

fi

#/build目录下面存放的是 这个.sh脚本和Dockerfile文件

cd ./build

验证 JAR 包#根据情况修改

###主要是查询对应项目下面有没有生成jar包

###需要手动添加对应关键词

if ! -f "../payment-api/target/"\*.jar ; then

echo "ERROR 未找到生成的 JAR 包"

exit 1

fi

2. Docker 检查

检查 Docker 是否安装

if ! command -v docker &> /dev/null; then

echo "ERROR Docker 未安装或不在 PATH 中"

exit 1

fi

检查 Docker 服务是否运行

if ! docker info &> /dev/null; then

echo "ERROR Docker 服务未运行"

exit 1

fi

3. 检测并删除已存在的同名镜像

echo "检测镜像是否存在: $IMAGE_TAG"

if docker images --format "{{.Repository}}:{{.Tag}}" | grep -q "^{** IMAGE_NAME**}** :**{ VERSION**}** $"; then

echo "发现已存在镜像 {** IMAGE_NAME**}** :**{ VERSION**}**,执行删除..."

停止关联容器

running_containers=(docker ps -a -q --filter "ancestor=**{** IMAGE_NAME**}** :${ VERSION**}**")

if -n "$running_containers" ; then

echo "停止关联容器:"

docker stop $running_containers

docker rm $running_containers

fi

删除镜像

docker rmi -f "{** IMAGE_NAME**}** :**{ VERSION**}**"

if $? -eq 0 ; then

echo "旧镜像删除成功!"

else

echo "警告:旧镜像删除失败,可能被其他容器引用" >&2

fi

else

echo "未发现同名镜像,继续构建..."

fi

4. 构建Docker镜像

执行 Docker 构建

echo "INFO 执行命令: docker build -f Dockerfile --build-arg ENV_FILE=ENV_FILE -t IMAGE_TAG ."

docker build -f Dockerfile --build-arg ENV_FILE="ENV_FILE" -t "IMAGE_TAG" ../

if $? -ne 0 ; then

echo "ERROR Docker 构建失败!"

exit 1

fi

5. 验证构建结果

# 验证镜像

echo "INFO 验证 Docker 镜像..."

if ! docker images | grep -q "wallet"; then

echo "ERROR Docker 镜像不存在: $IMAGE_TAG"

exit 1

fi

6. 删除临时文件

#rm -rf "$TARGET_DIR"

7. 上传镜像到habor镜像仓库

###docker push "{** IMAGE_NAME**}** :**{ VERSION**}**"

相关推荐
兰令水1 小时前
leecodecode【面试150】【2026.6.13打卡-java版本】
java·算法·leetcode
.道阻且长.2 小时前
C++ string 操作指南:接口解析
java·c语言·开发语言·c++
蚰蜒螟2 小时前
Java 对象的内存密语:从字段偏移量计算到 Unsafe 访问的完整链路
java·开发语言
IT 行者2 小时前
GitHub Spec Kit 实战(六):/speckit.implement 怎么用、怎么审、怎么发现 spec 阶段的遗漏——五部曲收官
java·驱动开发·github·ai编程·claude
星辰_mya2 小时前
CountDownLatch深度解析
java·开发语言·后端·架构
伊甸32 小时前
从企业级项目学敏感词过滤:DFA算法与双层缓存实战
java·算法·缓存
cfm_29142 小时前
JVM新一代垃圾收集器深度解析:G1与ZGC
java·jvm
laplaya2 小时前
使用 vcpkg 管理 C++ 项目中的依赖
开发语言·c++
x***r1512 小时前
.NET 10 SDK 安装教程(dotnet-sdk-10.0.100-win-x64详细步骤)
java·服务器·前端
摇滚侠2 小时前
MyBatis 入门到项目实战 MyBatis 的缓存 56-61
java·缓存·mybatis