tomcat/bin 目录下的catalina.sh是比较常用的shell
往往一个工程,开发一段时间后,会发现./catalina.sh stop关闭不了tomcat,而必须使用kill -9 <pid> 这样的强制命令去
杀死tomcat,这么做当然可以,但是手法不是那么的优雅
在tomat未被./catalina stop关闭的情况下,导致误以为tomcat已经关闭成功的哥们 会在更新完代码后,./catalina start一下,于是在服务器中就产生了2个tomcat的实例,log混乱,不知所措,ps 一看,大吃一惊,而后每次都用kill -9 <pid> 才放心。
其实不用那样,一般关闭不了的情况,是由于程序员自己在tomcat中开启了新的线程,而且未设置成daemon,造成的主线程不能退出.
怎么发现工程里到底哪里开启的新的非守护线程呢,其实jdk提供了jstack工具,可以帮助我们分析
查看方法很简单
pid是指进程ID, 用ps -ef|grep tomcat 就可以查看到:
这里看到的进程ID是 1513
调用jstack查看:
其中看到"Attach Listener" daemon prio=10 tid=0xb41d7c00 nid=0x606 waiting on condition [0x00000000]
java.lang.Thread.State: RUNNABLE
这行,最前变的"Attach Listener" 是线程名, 紧跟其后的 daemon是线程的守护状态,
其中主线程不是daemon的,所以是这样:
在"main" 后没有daemon,看到这样的线程状态,顺藤摸瓜,找到对应new Thread的地方setDaemon(true)就可以,痛痛快快的./catalina stop了 :)
Shell代码 1.#启动tomcat 2../catalina.sh start 3. 4.#关闭tomcat 5../catalina.sh stop #启动tomcat ./catalina.sh start #关闭tomcat ./catalina.sh stop
往往一个工程,开发一段时间后,会发现./catalina.sh stop关闭不了tomcat,而必须使用kill -9 <pid> 这样的强制命令去
杀死tomcat,这么做当然可以,但是手法不是那么的优雅
在tomat未被./catalina stop关闭的情况下,导致误以为tomcat已经关闭成功的哥们 会在更新完代码后,./catalina start一下,于是在服务器中就产生了2个tomcat的实例,log混乱,不知所措,ps 一看,大吃一惊,而后每次都用kill -9 <pid> 才放心。
其实不用那样,一般关闭不了的情况,是由于程序员自己在tomcat中开启了新的线程,而且未设置成daemon,造成的主线程不能退出.
怎么发现工程里到底哪里开启的新的非守护线程呢,其实jdk提供了jstack工具,可以帮助我们分析
查看方法很简单
$JAVA_HOME/bin/jstack <pid>
pid是指进程ID, 用ps -ef|grep tomcat 就可以查看到:
Shell代码 1.[root@localhost bin]# ps -ef|grep tomcat 2.root 1513 1 2 23:41 pts/1 00:00:01 /usr/local/share/java/jdk1.6.0_25/bin/java -Djava.util.logging.config.file=/opt/apache-tomcat-6.0.32/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.endorsed.dirs=/opt/apache-tomcat-6.0.32/endorsed -classpath /opt/apache-tomcat-6.0.32/bin/bootstrap.jar -Dcatalina.base=/opt/apache-tomcat-6.0.32 -Dcatalina.home=/opt/apache-tomcat-6.0.32 -Djava.io.tmpdir=/opt/apache-tomcat-6.0.32/temp org.apache.catalina.startup.Bootstrap start 3.root 1544 1462 0 23:42 pts/1 00:00:00 grep --color=auto tomcat [root@localhost bin]# ps -ef|grep tomcat root 1513 1 2 23:41 pts/1 00:00:01 /usr/local/share/java/jdk1.6.0_25/bin/java -Djava.util.logging.config.file=/opt/apache-tomcat-6.0.32/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.endorsed.dirs=/opt/apache-tomcat-6.0.32/endorsed -classpath /opt/apache-tomcat-6.0.32/bin/bootstrap.jar -Dcatalina.base=/opt/apache-tomcat-6.0.32 -Dcatalina.home=/opt/apache-tomcat-6.0.32 -Djava.io.tmpdir=/opt/apache-tomcat-6.0.32/temp org.apache.catalina.startup.Bootstrap start root 1544 1462 0 23:42 pts/1 00:00:00 grep --color=auto tomcat
这里看到的进程ID是 1513
调用jstack查看:
Shell代码 1.[root@localhost bin]# jstack 1513 2.2011-07-12 23:44:00 3.Full thread dump Java HotSpot(TM) Client VM (20.0-b11 mixed mode, sharing): 4. 5."Attach Listener" daemon prio=10 tid=0xb41d7c00 nid=0x606 waiting on condition [0x00000000] 6. java.lang.Thread.State: RUNNABLE 7. 8."TP-Monitor" daemon prio=10 tid=0xb41d6400 nid=0x5fa in Object.wait() [0xb3e0b000] 9. java.lang.Thread.State: TIMED_WAITING (on object monitor) 10. at java.lang.Object.wait(Native Method) 11. - waiting on <0x87143720> (a org.apache.tomcat.util.threads.ThreadPool$MonitorRunnable) 12. at org.apache.tomcat.util.threads.ThreadPool$MonitorRunnable.run(ThreadPool.java:565) 13. - locked <0x87143720> (a org.apache.tomcat.util.threads.ThreadPool$MonitorRunnable) 14. at java.lang.Thread.run(Thread.java:662) 15. 16."TP-Processor4" daemon prio=10 tid=0xb41d4c00 nid=0x5f9 runnable [0xb3e5c000] 17. java.lang.Thread.State: RUNNABLE 18. at java.net.PlainSocketImpl.socketAccept(Native Method) 19. at java.net.PlainSocketImpl.accept(PlainSocketImpl.java:408) 20. - locked <0x87124770> (a java.net.SocksSocketImpl) 21. at java.net.ServerSocket.implAccept(ServerSocket.java:462) 22. at java.net.ServerSocket.accept(ServerSocket.java:430) 23. at org.apache.jk.common.ChannelSocket.accept(ChannelSocket.java:311) 24. at org.apache.jk.common.ChannelSocket.acceptConnections(ChannelSocket.java:668) 25. at org.apache.jk.common.ChannelSocket$SocketAcceptor.runIt(ChannelSocket.java:879) 26. at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:690) 27. at java.lang.Thread.run(Thread.java:662) [root@localhost bin]# jstack 1513 2011-07-12 23:44:00 Full thread dump Java HotSpot(TM) Client VM (20.0-b11 mixed mode, sharing): "Attach Listener" daemon prio=10 tid=0xb41d7c00 nid=0x606 waiting on condition [0x00000000] java.lang.Thread.State: RUNNABLE "TP-Monitor" daemon prio=10 tid=0xb41d6400 nid=0x5fa in Object.wait() [0xb3e0b000] java.lang.Thread.State: TIMED_WAITING (on object monitor) at java.lang.Object.wait(Native Method) - waiting on <0x87143720> (a org.apache.tomcat.util.threads.ThreadPool$MonitorRunnable) at org.apache.tomcat.util.threads.ThreadPool$MonitorRunnable.run(ThreadPool.java:565) - locked <0x87143720> (a org.apache.tomcat.util.threads.ThreadPool$MonitorRunnable) at java.lang.Thread.run(Thread.java:662) "TP-Processor4" daemon prio=10 tid=0xb41d4c00 nid=0x5f9 runnable [0xb3e5c000] java.lang.Thread.State: RUNNABLE at java.net.PlainSocketImpl.socketAccept(Native Method) at java.net.PlainSocketImpl.accept(PlainSocketImpl.java:408) - locked <0x87124770> (a java.net.SocksSocketImpl) at java.net.ServerSocket.implAccept(ServerSocket.java:462) at java.net.ServerSocket.accept(ServerSocket.java:430) at org.apache.jk.common.ChannelSocket.accept(ChannelSocket.java:311) at org.apache.jk.common.ChannelSocket.acceptConnections(ChannelSocket.java:668) at org.apache.jk.common.ChannelSocket$SocketAcceptor.runIt(ChannelSocket.java:879) at org.apache.tomcat.util.threads.ThreadPool$ControlRunnable.run(ThreadPool.java:690) at java.lang.Thread.run(Thread.java:662)
其中看到"Attach Listener" daemon prio=10 tid=0xb41d7c00 nid=0x606 waiting on condition [0x00000000]
java.lang.Thread.State: RUNNABLE
这行,最前变的"Attach Listener" 是线程名, 紧跟其后的 daemon是线程的守护状态,
其中主线程不是daemon的,所以是这样:
"main" prio=10 tid=0xb6d05000 nid=0x5ea runnable [0xb6ee9000] java.lang.Thread.State: RUNNABLE at java.net.PlainSocketImpl.socketAccept(Native Method) at java.net.PlainSocketImpl.accept(PlainSocketImpl.java:408) - locked <0x871644a8> (a java.net.SocksSocketImpl) at java.net.ServerSocket.implAccept(ServerSocket.java:462) at java.net.ServerSocket.accept(ServerSocket.java:430) at org.apache.catalina.core.StandardServer.await(StandardServer.java:431) at org.apache.catalina.startup.Catalina.await(Catalina.java:676) at org.apache.catalina.startup.Catalina.start(Catalina.java:628) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) at java.lang.reflect.Method.invoke(Method.java:597) at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289) at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
在"main" 后没有daemon,看到这样的线程状态,顺藤摸瓜,找到对应new Thread的地方setDaemon(true)就可以,痛痛快快的./catalina stop了 :)
发表评论
-
log4j 产生的日志位置设置 和 catalina.home、catalina.base .
2013-02-20 10:35 2512方法一、 解决的办法自 ... -
<context-param>与<init-param>的区别与作用
2013-02-20 10:07 796<context-param>的作用: web.x ... -
Tomcat指定jdk
2013-01-23 16:51 40541.Linux下为Tomcat指定jdk 一、全局设置。 ... -
web.xml配置文件总结
2013-01-22 10:30 1043每一个规范的web应用在W ... -
tomcat命令提示符和两种tomcat安装方式 .
2013-01-17 19:07 9281. 一些用到的命令提示符经指令。 在cmd中启 ... -
2010-01-08 22:43 小议 java:comp/env
2012-12-21 17:49 760在描述JNDI,例如获得数据源时,JNDI地址有两种写法,例如 ...
相关推荐
本文将深入探讨导致Tomcat自动关闭的原因,以便采取有效措施预防和解决此类问题。 ### 1. Tomcat配置不当 Tomcat自动关闭的第一个常见原因是配置不当。这包括但不限于以下几点: - **内存配置**:如果Tomcat的JVM...
### Tomcat不能启动的原因及解决方法 #### 一、引言 Apache Tomcat是一款开源的Servlet容器,主要用于部署Java Web应用程序。然而,在实际使用过程中,可能会遇到Tomcat无法正常启动的情况。本文将根据提供的文件...
tomcat shutdown后,进程还存在linux系统中的解决办法
Shell脚本定时监控tomcat,服务挂掉自动重启
问题的原因是 Tomcat 的日志配置不正确,导致详细错误日志不可见。解决该问题需要配置 Log4j,这是一个流行的 Java 日志记录工具。 首先,需要将 Log4j 的 lib 包放在 Tomcat 的 lib 目录下,然后在 lib 目录新建一...
tomcat最新客户端tomcat最新客户端tomcat最新客户端tomcat最新客户端tomcat最新客户端tomcat最新客户端tomcat最新客户端tomcat最新客户端tomcat最新客户端tomcat最新客户端tomcat最新客户端tomcat最新客户端tomcat...
Tomcat7、Tomcat8和Tomcat9是不同版本的Tomcat,每个版本都有其特性和改进。 **Tomcat7**: Tomcat7是2011年发布的,它主要支持Java Servlet 3.0和JSP 2.2规范。这个版本引入了一些重要改进,包括增强的安全性、更...
标题和描述中提到的问题主要涉及如何安装监控Tomcat服务,以防止Tomcat因故障而停止服务,导致系统不可用。以下是对这些知识点的详细说明: 1. **Tomcat监控服务**: - 安装Tomcat监控服务是为了实时检查Tomcat...
如果安装的JRE/JDK版本与Tomcat不兼容,或者系统中存在多个版本的JRE/JDK,可能会导致Tomcat启动失败。 - 解决方案:确保安装了正确的JRE/JDK版本,并检查`CATALINA_HOME/bin/catalina.sh`或`CATALINA_HOME/bin/...
标题“TOMCAT不能正常启动总结”涉及到的是在部署和运行Apache Tomcat服务器时遇到的问题。Tomcat是一款广泛使用的开源Java应用服务器,主要用于运行Servlet和JSP应用。当Tomcat无法正常启动时,可能的原因多样,...
为确保系统稳定运行,及时对Tomcat进行补丁更新至关重要。 #### 二、查找并下载对应版本的安全补丁 1. **访问官方网站**:首先,登录Apache Tomcat的官方网站(http://tomcat.apache.org/),找到“Security”部分...
在某些情况下,可能会遇到Tomcat的某个端口被占用但进程却找不到的情况。这时可以尝试通过端口号找到对应的PID: ```bash netstat -anp | grep ``` 假设我们知道Tomcat占用的端口是9217,则可以使用: ```...
标题中的“tomcat7.0下的64位的tomcat7.exe 和tomcat7w.exe”指的是Apache Tomcat服务器在7.0版本中为64位操作系统提供的可执行文件。Tomcat是Apache软件基金会的一个开源项目,它是一个流行的Java Servlet容器,...
tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0tomcat 5.0
部署网站必不可缺少的tomcat安装包~~部署网站必不可缺少的tomcat安装包~~部署网站必不可缺少的tomcat安装包~~部署网站必不可缺少的tomcat安装包~~部署网站必不可缺少的tomcat安装包~~部署网站必不可缺少的tomcat...
4. **JAR(Java Archive)文件**:Tomcat目录结构中的lib目录包含了运行Tomcat所需的各种JAR文件,如Servlet API和其他依赖库,这些库对于正确运行Web应用至关重要。 5. **Web应用程序目录结构**:一个标准的Tomcat...
标题 "tomcat 启动报APR based Apache Tomcat Native library not found" 指出的问题是关于Apache Tomcat服务器在启动时找不到基于APR(Apache Portable Runtime)的本机库。这通常涉及到Tomcat使用APR库来提高性能...
### Tomcat 5.5启动报错原因分析 #### 1. 配置文件问题 在Tomcat 5.5中,`C:\tomcat5\conf\Catalina\localhost`目录下的配置文件对于服务器的正常运行至关重要。如果此目录下只存在一个名为`techart.xml`的文件,而...
根据提供的信息,我们可以总结出以下知识点: ...通过以上知识点的学习,可以了解到如何通过Java程序实现对Tomcat服务器状态的自动检测与重启,这对于保障基于Tomcat的应用系统持续可用具有重要意义。
tomcat