分析java程序

本文通过使用jstack工具排查了一项账单推送服务中的Java进程假死问题,详细记录了发现服务延迟、定位问题到Tomcat应用无响应的过程,并对比分析了不同JDK环境下进程状态的差异。

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

最近公司的一个账单推送的服务,发现有延迟。我排查的时候发现,有一个程序日志不动了(采用消息队列,部署了两台服务器来负载均衡)。 网上说: jstack 可以来排查。

可以观察到jvm中当前所有线程的运行情况和线程当前状态. sudo jstack -F 进程ID 输出内容如下: 从上面的图我们可以看到tomcat进程里面没有死锁的情况,而且每个线程都处理等待的状态。这个时候我们可以telnet命令连上tomcat的端口查看tomcat进程是否有任务回应。这时发现tomcat没有任何回应可以证明tomcat应用已没有响应处理假死状态。

分析java进程假死状况

但是一台服务器可以,一台服务器不可以。

因为一台服务器采用的是oracle的jdk,一台采用的是openjdk (都是linux ubuntu服务器)

网上说得安装 sudo apt-get install openjdk-8-dbg

不过得重启一下应用,不然还是不能用的jstack

转载于:https://my.oschina.net/miaojiangmin/blog/3012318

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值