最近公司的一个账单推送的服务,发现有延迟。我排查的时候发现,有一个程序日志不动了(采用消息队列,部署了两台服务器来负载均衡)。 网上说: jstack 可以来排查。
可以观察到jvm中当前所有线程的运行情况和线程当前状态. sudo jstack -F 进程ID 输出内容如下: 从上面的图我们可以看到tomcat进程里面没有死锁的情况,而且每个线程都处理等待的状态。这个时候我们可以telnet命令连上tomcat的端口查看tomcat进程是否有任务回应。这时发现tomcat没有任何回应可以证明tomcat应用已没有响应处理假死状态。
但是一台服务器可以,一台服务器不可以。
因为一台服务器采用的是oracle的jdk,一台采用的是openjdk (都是linux ubuntu服务器)
网上说得安装 sudo apt-get install openjdk-8-dbg
不过得重启一下应用,不然还是不能用的jstack