tomcat 定时重启

tomcat 定时重启

1.编写脚本

su - tomcat

tomcat@u1abomap02 \~\]$ ls restart_tomcat_gosi.sh tomcat_gosi.log

bash 复制代码
vi restart_tomcat_gosi.sh 


#!/bin/bash

# 定义日志目录
LOG_DIR="/home/tomcat"
LOG_FILE="$LOG_DIR/tomcat_gosi.log"


# 设置环境变量(关键)
export JAVA_HOME=/usr/local/jdk1.6.0_43
export JRE_HOME=$JAVA_HOME/jre
export PATH=$JAVA_HOME/bin:$PATH

# 记录环境信息用于调试
echo "$(date): Starting restart script. JAVA_HOME=$JAVA_HOME, PATH=$PATH" >> "$LOG_FILE"

# 查找进程 ID
PID=$(pgrep -f "tomcat-gosi.*10.26.203.95")

# 检查是否找到进程
if [ -n "$PID" ]; then
    echo "$(date): Killing process with PID: $PID" >> "$LOG_FILE"
    kill -9 $PID
    if [ $? -eq 0 ]; then
        echo "$(date): Process $PID killed successfully." >> "$LOG_FILE"
    else
        echo "$(date): Failed to kill process $PID." >> "$LOG_FILE"
    fi
    sleep 5
else
    echo "$(date): No process found for tomcat-gosi with IP 10.26.203.95." >> "$LOG_FILE"
fi


# 重启 Tomcat 直到成功启动
MAX_ATTEMPTS=5
attempt=1


while [ $attempt -le $MAX_ATTEMPTS ]; do
    echo "$(date): Starting Tomcat (Attempt $attempt of $MAX_ATTEMPTS)..." >> "$LOG_FILE"
    sh /soft/tomcat-gosi/bin/startup.sh >> "$LOG_FILE" 2>&1
    # 等待启动
    sleep 10

    # 判断是否真正在运行
    if pgrep -f "tomcat-gosi.*10.26.203.95" > /dev/null; then
        echo "$(date): Tomcat is running." >> "$LOG_FILE"
        exit 0
    else
        echo "$(date): Failed to start Tomcat (process not found)." >> "$LOG_FILE"
        # 输出 Tomcat 错误日志片段
        echo "$(date): Last 10 lines of catalina.out:" >> "$LOG_FILE"
        tail -n 10 /soft/tomcat-gosi/logs/catalina.`date +%Y-%m-%d`.out >> "$LOG_FILE" 2>&1 || echo "catalina.out not accessible" >> "$LOG_FILE"
    fi


    #if [ $? -eq 0 ]; then
    #    echo "$(date): Tomcat started successfully." >> "$LOG_FILE"
    # 成功启动后退出脚本
    #   exit 0  
    #else
    #    echo "$(date): Failed to start Tomcat on attempt $attempt." >> "$LOG_FILE"
    #fi

    attempt=$((attempt + 1))
     # 等待 5 秒再重试
    sleep 5  
done

echo "$(date): Tomcat failed to start after $MAX_ATTEMPTS attempts." >> "$LOG_FILE"
# 超过最大尝试次数后退出脚本
exit 1  

2.创建定时任务

sh 复制代码
[tomcat@u1abomap02 ~]$ crontab -l
35 7 * * 1-5   /home/tomcat/restart_tomcat_gosi.sh
相关推荐
苏宸啊8 小时前
Linux指令篇(一)
linux·运维·服务器
睡不醒的猪儿8 小时前
nginx常见的优化配置
运维·nginx
我要升天!8 小时前
Linux中《网络基础》
linux·运维·网络
国强_dev9 小时前
在数据库开发和运维中的“错误信息误导(Red Herring)”
运维·adb·数据库开发
安科瑞刘鸿鹏179 小时前
工业自动化系统中抗晃电保护的协同控制研究
运维·网络·嵌入式硬件·物联网
ZStack开发者社区9 小时前
ZStack Cloud 5.5.0正式发布
运维·服务器·网络
草莓熊Lotso9 小时前
脉脉独家【AI创作者xAMA】|当豆包手机遭遇“全网封杀”:AI学会操作手机,我们的饭碗还保得住吗?
运维·开发语言·人工智能·智能手机·脉脉
三不原则9 小时前
银行 AIOps 实践拆解:金融级故障自愈体系如何搭建
大数据·运维
晴天¥10 小时前
VMware+Oracle linux LVM/非LVM磁盘扩容
linux·运维·服务器
醇氧11 小时前
Ping 127.0.0.1 具有 32 字节的数据:一般故障。【二】
运维·服务器·开发语言