Jenkins构建完,jar包启动不起来?

简介

Jenkins 是一款自动化部署项目的工具,可通过可视化的管理界面,实现对项目的构建部署。

本文介绍一次构建完工程,执行运行脚本后,项目起不来的问题。

场景

启动项目的脚本如下,很普通的启动脚本。

shell 复制代码
#!/bin/bash

APP_NAME="no_database_demo-1.0-SNAPSHOT"
JAR_PATH="/root/.jenkins/workspace/no_database_demo/target/${APP_NAME}.jar"
LOG_PATH="/var/log/${APP_NAME}.log"
PID_FILE="/var/run/${APP_NAME}.pid"  # 新增:定义PID文件路径
JAVA_CMD="/usr/local/dev/jdk-21.0.5/bin/java"

# --- 核心:通过PID文件杀死旧实例 ---
echo "正在停止所有旧的 $APP_NAME 进程..."
if [ -f "$PID_FILE" ]; then
    OLD_PID=$(cat "$PID_FILE")
    if ps -p $OLD_PID > /dev/null; then
        echo "停止进程 $OLD_PID..."
        kill $OLD_PID
        sleep 3
        if ps -p $OLD_PID > /dev/null; then
            kill -9 $OLD_PID
        fi
    fi
    rm -f $PID_FILE
fi

# --- 启动新进程并写入PID文件 ---
echo "启动 $APP_NAME..."
nohup "$JAVA_CMD" -jar "$JAR_PATH" > "$LOG_PATH" 2>&1 &
NEW_PID=$!
echo $NEW_PID > $PID_FILE
echo "启动成功,PID: $NEW_PID"

Jenkins 中点击立即构建后,确定是执行了这个脚本,因为控制台打印了 "启动成功,PID:XXX" 日志。

但是回到服务器,使用 jps 命令就是看不到运行中的 Java 程序。

更可恶的是,如果此时在服务器里手动执行这个脚本,jar 包就能被启动起来。

解决

最终排查是因为 Jenkins 在构建完一个工程后,会将所有相关的子进程杀死,我这个 jar 进程刚启动就被 Jenkins 杀死了。

需要在执行脚本开头加一行 "宇宙安全声明"。

shell 复制代码
# 禁用 Jenkins 进程收割
export BUILD_ID=dontKillMe

修改后如下:

shell 复制代码
#!/bin/bash

# 禁用 Jenkins 进程收割
export BUILD_ID=dontKillMe

APP_NAME="no_database_demo-1.0-SNAPSHOT"
JAR_PATH="/root/.jenkins/workspace/no_database_demo/target/${APP_NAME}.jar"
LOG_PATH="/var/log/${APP_NAME}.log"
PID_FILE="/var/run/${APP_NAME}.pid"  # 新增:定义PID文件路径
JAVA_CMD="/usr/local/dev/jdk-21.0.5/bin/java"

# --- 核心:通过PID文件杀死旧实例 ---
echo "正在停止所有旧的 $APP_NAME 进程..."
if [ -f "$PID_FILE" ]; then
    OLD_PID=$(cat "$PID_FILE")
    if ps -p $OLD_PID > /dev/null; then
        echo "停止进程 $OLD_PID..."
        kill $OLD_PID
        sleep 3
        if ps -p $OLD_PID > /dev/null; then
            kill -9 $OLD_PID
        fi
    fi
    rm -f $PID_FILE  # 删除旧PID文件
fi

# --- 启动新进程并写入PID文件 ---
echo "启动 $APP_NAME..."
nohup "$JAVA_CMD" -jar "$JAR_PATH" > "$LOG_PATH" 2>&1 &
NEW_PID=$!
echo $NEW_PID > $PID_FILE  # 写入新PID到文件
echo "启动成功,PID: $NEW_PID"
相关推荐
goyeer12 小时前
【ITIL4】- 服务价值体系
大数据·运维·信息化·自动运维·itil
精益数智小屋12 小时前
设备维护方案核心功能拆解:一套好的设备维护方案如何解决设备突发故障
大数据·运维·网络·数据库·人工智能·面试·自动化
SWAGGY..12 小时前
Linux系统编程:(一)基础指令详解
linux·运维·服务器
Agent产品评测局12 小时前
设备运维自动化预警系统,从0到1落地实操方法:2026企业级架构与智能体选型全指南
运维·人工智能·ai·chatgpt·架构·自动化
一池秋_12 小时前
etc/sudo.conf is owned by uid 10258, should be 0解决
linux·运维·服务器
dingdingfish12 小时前
TLPI 第19 章 练习:Monitoring File Events
linux·inotify·tlpi·exercise
Bert.Cai12 小时前
Linux basename命令详解
linux·运维·服务器
源远流长jerry12 小时前
Linux 本机网络通信机制深度解析:Loopback 设备原理
linux·运维·服务器·网络·tcp/ip·nginx·负载均衡
一只小bit13 小时前
Docker 镜像制作:包含自定义镜像及常用命令
运维·docker·容器
源远流长jerry13 小时前
Linux 网络性能优化:从应用到内核
linux·运维·服务器·网络·网络协议·性能优化