java - JVM自动终止时如何生成线程转储

标签 java jvm

问题场景:问题出现在 sonic MF 容器(jvm)中。该容器托管了一些负责数据库操作和消息转换的 java 服务。一旦启动,该容器可以正常运行 2-3 周,然后由其终止拥有而不抛出任何异常。

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

有没有一种方法可以在 jvm 自动关闭时获取线程转储?我正在使用 Java 1.6。对于这个问题,我应该遵循任何其他方法吗?

提前致谢。

最佳答案

你可以试试 java.lang.Runtime.addShutdownHook() ,并让钩子(Hook)遍历所有线程并使用 Thread.getAllStackTraces() 转储它们的堆栈跟踪.但是,如果 JVM 被 Runtime.halt() 关闭,则不会调用 Hook 。更复杂的是使用 instrumentation挂接到对 Runtime.exit()Runtime.halt() 的调用(或 Shutdown.sequence(),请参阅编辑 #2 ),这样您就可以准确地看到调用任何一个时发生了什么。

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

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

关于java - JVM自动终止时如何生成线程转储,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10714828/

相关文章:

java - 是否有 Java 类文件格式的声明性正式规范?

java - 创建具有更大对象头的自定义 JVM

java - JVM 内部分析器?

java - jvm - 关于代码缓存区

java - 实现事件驱动的轻量级线程

java - Cassandra 一致性级别规则

java - 如何在 .classpath 中添加对 .properties 文件的引用

java - 中断异常捕获中的方法调用是否会完成 run() 方法并使线程完成

java - Oracle 和 Jdbc 以及 OraclePreparedStatement#setPlsqlIndexTable 和 java.util.Date

java - Hadoop java mapper -copyFromLocal 堆大小错误