Linux环境Tomcat不能被shutdown.sh正常关闭

问题分析

在Linux环境下,使用shutdown.sh脚本关闭Tomcat,经常会出现无法正常关闭的情况,使用ps -ef命令查看发现仍然有tomcat的进程。

查看linux日志以及源代码,问题出在WebappClassLoaderBase中,此类为Context的类加载器父类,在容器关闭时,会调用其stop方法,stop方法会调用clearReferencesThreads方法


private boolean clearReferencesStopThreads = false;

private void clearReferencesThreads() {
        Thread[] threads = getThreads();
        List<Thread> executorThreadsToStop = new ArrayList<>();

        // Iterate over the set of threads
        for (Thread thread : threads) {
            if (thread != null) {
               		
               		...省略其他代码...

                    // Don't try and stop the threads unless explicitly
                    // configured to do so
                    if (!clearReferencesStopThreads) {
                        continue;
                    }

                   ...省略其他代码...     
    }

如果存在仍然运行的线程,根据代码默认的配置,则不会进行任何处理,所以tomcat的进程仍然会存在。

解决方案

解决这个问题的思路为,通过kill命令强制杀掉进程,本文提供两种方案。

1.自己编写shell脚本

其思路为先查询到tomcat的进程ID,然后杀掉进程,具体shell脚本如下:

#!/bin/bash
#TOMCAT_BASE为服务器上tomcat的bin目录路径
export TOMCAT_BASE=/usr/local/tomcat/7.0/bin
echo ' >>> deploy start'

#仍然先运行shutdown.sh脚本关闭tomcat
sh $TOMCAT_BASE/shutdown.sh
#查询tomcat的进程ID,并杀掉该进程
pidList=$(ps aux | grep $TOMCAT_BASE | grep -v grep | awk '{print $2}')
for pid in $pidList
do
kill -9 $pid
echo 'kill pid '$pid
done

#启动tomcat
sh $TOMCAT_BASE/startup.sh
echo ' >>> deploy end'

通过以上脚本,可以重启Tomcat。此方式的风险在于查找tomcat的进程ID是否准确,但可以一并杀掉因人为操作shutdown.sh而未关闭的进程。

2.Tomcat预留的窗口

在Tomcat的catalina.sh中预留了该问题的处理窗口,需进行以下配置:

  1. 在bin目录中创建文件,文件名为CATALINA_PID
  2. 在shutdown.sh中增加参数-force
exec "$PRGDIR"/"$EXECUTABLE" stop -force  "$@"
  1. 在catalina.sh中最前面变量 P R G D I R 定 义 后 增 加 以 下 代 码 , 将 变 量 PRGDIR定义后增加以下代码,将变量 PRGDIRCATALINA_PID指向创建的CATALINA_PID文件,在Tomcat启动时,会将进程ID存储在这个文件中。
if [ -z "$CATALINA_PID" ]; then
   CATALINA_PID=$PRGDIR/CATALINA_PID
fi

至此,运行shutdown.sh,当tomcat无法正常关闭时,会强制杀掉tomcat的进程。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值