Tomcat不能正常shutdown的问题

本文记录了在WinXP环境下,使用Tomcat 6.0.18与JDK 1.6u14时遇到的Tomcat关闭延迟现象及解决过程。作者通过更换不同版本的Tomcat和JDK排除软件版本问题,最终定位为操作系统注册表中TCP/IP参数配置不当导致。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

环境:

winxp + tomcat6.0.18 + jdk1.6u14

 

现象:

tomcat有个脚本shutdown.bat可以停止运行中的tomcat, 最近发现执行shutdown.bat后tomcat不能马上停止, 需要等个10几秒才会报错停止;

-----------------------------

2009-6-23 23:07:26 org.apache.catalina.startup.Catalina stopServer
严重: Catalina.stop:
java.net.ConnectException: Connection refused: connect
    at java.net.PlainSocketImpl.socketConnect(Native Method)
    at java.net.PlainSocketImpl.doConnect(Unknown Source)
    at java.net.PlainSocketImpl.connectToAddress(Unknown Source)
    at java.net.PlainSocketImpl.connect(Unknown Source)
    at java.net.SocksSocketImpl.connect(Unknown Source)
    at java.net.Socket.connect(Unknown Source)
    at java.net.Socket.connect(Unknown Source)
    at java.net.Socket.<init>(Unknown Source)
    at java.net.Socket.<init>(Unknown Source)
    at org.apache.catalina.startup.Catalina.stopServer(Catalina.java:421)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
    at java.lang.reflect.Method.invoke(Unknown Source)
    at org.apache.catalina.startup.Bootstrap.stopServer(Bootstrap.java:337)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:415)
-----------------------------

 

排查:

首先google, 全是垃圾信息, 一个没用!

最先怀疑是jdk1.6从u13升级到u14的问题, 因为原来是可以的, 换jdk问题依旧, 排除jdk版本嫌疑;

换tomcat版本, 问题依旧, 排除tomcat版本嫌疑;

换机器, 问题解决, 定位是os设置的问题;

 

原因:

回想起前一段调试nio程序, 参照ibm的一篇文档(http://publib.boulder.ibm.com/wasce/V2.1.0/zh_CN/tuning-windows.html )用regedit改了HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\TCPIP\Parameters 下的配置, 就是这个改动引起的!

 

解决:

把增加的TcpTimedWaitDelay , MaxUserPort 项删除, 重启操作系统, 问题解决.

Tomcat是一个开源的Java Web服务器,它是Apache软件基金会的一个项目。当我们停止Tomcat服务器时,可能会遇到Tomcat shutdown进程仍在运行的情况。 出现这种情况通常是由于某些正在运行的任务或线程没有正确关闭所致。在关闭Tomcat服务器时,Tomcat会尝试结束所有正在运行的任务和线程,然后关闭自身。但有时候,如果存在某些无法正常结束的任务或线程,就会导致Tomcat shutdown进程仍然存在。 要解决这个问题,我们可以尝试以下几种方法: 1. 查找并终止相关的进程:使用任务管理器或命令行工具,查找并手动终止与Tomcat相关的进程。通常可以通过进程名称或进程ID来识别。终止这些进程后,Tomcat shutdown进程应该会消失。 2. 强制关闭进程:如果无法通过常规方法终止Tomcat shutdown进程,我们可以尝试使用`kill`命令(在UNIX或Linux系统上)或`taskkill`命令(在Windows系统上)来强制关闭该进程。这需要在命令行中执行相应的命令,并提供Tomcat shutdown进程的进程ID。 3. 检查Tomcat日志文件:查看Tomcat服务器的日志文件,例如catalina.out或catalina.log,以获取关于无法正常关闭的任务或线程的更多信息。根据日志中的报错信息,可以尝试修复相关的问题,并重新启动Tomcat服务器。 总的来说,当Tomcat shutdown进程仍然存在时,我们可以尝试通过手动终止相关进程、强制关闭进程以及检查Tomcat日志文件来解决该问题。这些方法将帮助我们确保Tomcat服务器完全关闭,并可以重新启动或进行其他需要操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值