基于jstack的一次问题调查

jstack 

http://www.open-open.com/lib/view/open1456744049953.html 
http://wenku.baidu.com/link?url=XGRAXwZGpPIyvYzcs0fqOGazbnKWWy6tsuDk5XhPUmVI4Y9jOT5TiYf6JVq0sPGafvMJmZFs1dNDlNtovldedF5xwr9ViMvv6WdRSaTGkn_

    (案例:转)公司的一个web应用项目运行了很长一段时间,达半年之久,前段时间突然出现了服务不可用的情况,所有的请求都不可达,服务彻底挂了。查看tomcat进程还在,cpu使用率低,一时没找着问题,重启了服务。过了两天,又出现了这种情况, 开始排查最近更新上线的代码,但是也没有发现可疑之处。 
    
     开始怀疑JVM内存不够用了,通过jmap/jstat查看后,也没有发现存在JVM内存不够用,或者GC太频繁或者是FGC耗时太久的情况。 
    
     接着下来用jstack -F pid 把所有的线程信息dump下来,发现了很多“Thread 2341: IN_NATIVE”的线程,而且都来自同一个类;定位到该类,里面用了socket去跟第三方接口做交互,而socket没有设置SoTimeout时间,这样的话,socket将永久地等待,直到inputStream有数据; socket.setSoTimeout(3000)之后,报出了很多Read  timed out 的异常信息,很明显就是第三方接口出问题了。 
     
    所以出现故障的原因就是:一个http请求过来,tomcat接收到请求,分配一个worker Thread处理它,处理该请求的代码用到了前面提到的类,该worker Thread将永久处于socket.read()方法的wait状态或者说是IN_NATIVE状态;当时间一长,所有的worker thread都被占用,都处于socket.read()方法的wait状态后,tomcat没有worker thread处理任何的http请求了,故而应用会彻底挂掉;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java内存泄漏是指在程序运行过程中,由于程序设计不当或者其他原因,导致程序中的一些对象在没有被使用的情况下仍然占用着内存空间,这些对象无法被垃圾回收器回收,最终导致程序内存泄漏的问题。下面介绍一些Java内存泄漏问题调查定位方法。 1. 使用jmap命令 jmap是Java虚拟机自带的一个命令行工具,可以用来生成Java堆转储快照。使用jmap命令可以查看当前Java虚拟机堆内存中的对象分布情况,以及各个对象的数量和大小等信息。通过分析jmap生成的快照可以定位内存泄漏的问题所在。 2. 使用jstack命令 jstack也是Java虚拟机自带的一个命令行工具,用于生成Java虚拟机当前线程的堆栈信息。当程序出现死锁或者线程阻塞等问题时,可以使用jstack命令查看当前线程的堆栈信息,以帮助定位问题所在。 3. 使用内存分析工具 除了使用命令行工具外,还可以使用一些内存分析工具来帮助定位内存泄漏问题。常用的内存分析工具有Eclipse Memory Analyzer(MAT)、VisualVM等。这些工具可以帮助我们分析Java堆转储快照,查找内存泄漏的原因,并提供针对具体问题的解决方案。 4. 定期检查代码 除了使用工具外,我们还应该定期检查程序的代码,发现并修复潜在的内存泄漏问题。常见的内存泄漏问题包括对象未被正确释放、缓存对象未被清理等。修复这些问题可以有效地避免内存泄漏的发生。 总之,Java内存泄漏问题调查定位需要综合使用各种工具和方法,找到问题所在并及时解决。通过定期检查程序代码,加强对Java内存管理的理解和掌握,可以有效地预防和避免内存泄漏问题的发生。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值