3

问题场景:在sonic MF容器(jvm)中发现了问题。容器托管了一些负责db操作和消息转换的java服务。一旦启动,容器可以正常运行2-3周,并自行终止而不会抛出任何例外。

经过大量研究,我们无法找出导致 jvm(MF 容器)关闭的原因或原因。

当jvm自动关闭时,有没有一种方法可以让我获得线程转储?我正在使用java 1.6。我应该遵循这个问题的其他方法吗?

提前致谢。

4

2 回答 2

5

您可以尝试java.lang.Runtime.addShutdownHook(),并让钩子遍历所有线程并使用Thread.getAllStackTraces()转储它们的堆栈跟踪。但是,如果 JVM 已关闭,Runtime.halt()则不会调用挂钩。更复杂的是使用检测来挂钩Runtime.exit()Runtime.halt()(或Shutdown.sequence(),请参阅编辑#2)的调用,因此您可以准确地看到在调用任何一个时发生的情况。

编辑:另一种方法是安装一个不强制执行任何安全性的SecurityManagerSecurityManager.checkExit() ,但它会在调用时转储线程列表,因为两者都halt()调用exit()该安全管理器方法。这将比使用检测容易得多,您甚至可以决定在记录线程正在做什么之外抛出异常。

编辑 2:运行 JVM 的系统可以告诉 JVM 终止,在这种情况下使用安全管理器将不起作用。也不会在Runtime.exit()or上使用检测Runtime.halt(),因为被调用的方法是java.lang.Shutdown.exit(). 如果 JVM 因为最后一个守护线程完成而关闭,Shutdown.shutdown()则调用。但是关闭钩子在任何一种情况下都可以工作。因此,您应该始终使用关闭挂钩,即使您还要使用安全管理器或工具。

于 2012-05-23T07:17:13.647 回答
0

另请参阅https://docs.oracle.com/javase/7/docs/webnotes/tsg/TSG-VM/html/hangloop.html “解决挂起或循环过程”

但是,至少在我的情况下,Eclipse 被挂起,并且不响应任何这些。

于 2018-02-24T07:03:00.700 回答