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"
相关推荐
Soari2 分钟前
SSH 主机密钥冲突
运维·网络·ssh
爱莉希雅&&&8 分钟前
zabbix快速搭建和使用
android·linux·数据库·zabbix·监控
z2005093015 分钟前
【linux学习】深入理解linux文件I/O,从C标准库到内核态
linux·学习·操作系统
黑泽明Coding34 分钟前
使用密钥登录ssh
运维·ssh
weixin_307779131 小时前
面向高性能保密计算的定制 Linux 系统构建与自动部署方案
linux·安全·网络安全·性能优化·系统安全
着迷不白1 小时前
五、文本处理工具+正则表达式
linux·运维·服务器
Elastic 中国社区官方博客1 小时前
每次操作一个 API 调用:Elastic Cloud Hosted 如何让大规模部署管理变得可行
大数据·运维·数据库·elasticsearch·搜索引擎·serverless
载数而行5201 小时前
Linux 4常用指令(文件/时间/搜索查找/压缩解压指令)
linux
不做无法实现的梦~2 小时前
MAVLink 协议教程
linux·stm32·嵌入式硬件·算法
江华森2 小时前
Zabbix 6.4 全栈部署与运维完全指南
运维·zabbix