在生产环境中执行线程转储
我正在分析获取线程转储的方法之间的差异。以下是我正在研究的几个
定义一个 jmx bean,它在单击声明的 bean 操作时通过 Runtime.exec() 触发 jstack。
Daemon 线程在预定义的时间间隔后重复执行“ManagementFactory.getThreadMXBean().dumpAllThreads(true, true)”。
比较两者之间的线程转储输出,我看到了方法2的以下缺点
- 使用方法 2 记录的线程转储无法由开源线程转储分析器(如 TDA)解析
- 输出不包括本机线程 ID,这可能有助于分析高 CPU 问题(对吧?)
- 还有更多吗?
我很乐意获得有关以下方面的建议/意见
在生产代码中通过 Runtime.exec() 执行 jstack 有什么缺点吗?各种操作系统上的任何兼容性问题 - Windows,linux?
是否有任何其他方法可以获取线程转储?
谢谢。
编辑 -
1 和 2 的组合方法似乎是要走的路。我们可以让一个专用线程在后台运行,并以线程转储分析器可以理解的格式在日志文件中打印线程转储。如果需要任何额外的信息(比如说可能是本机线程ID),这些信息仅由jstack输出记录,我们会根据需要手动执行。