
我们生产环境,总是有 JAVA 线程莫名其妙的消失,有没有什么软件可以看到 JVM 什么时候把这些线程回收了?或者可以找到证据来证明这个线程确实是被 JVM 回收了? 我们从日志上看,这个线程肯定是运行一半被回收了,但是找不到证据。各位大神怎么找证据?
1 wysnylc 2020-01-17 16:32:01 +08:00 抛异常了而且你们捕获了但是没打印栈吧 |
2 chendy 2020-01-17 16:36:18 +08:00 线程不会无缘无故地消失,要么出异常了要么跑完了 目测是异常处理不当丢信息了… |
3 awfe 2020-01-17 16:36:18 +08:00 有异常了吧 |
4 yumenawei 2020-01-17 16:37:54 +08:00 我猜你们是用的默认的线程池,然后线程莫名没了。 |
6 Raymon111111 2020-01-17 17:52:54 +08:00 全局 try catch |
7 palmers 给自己的线程定义名称 然后再排查 楼上说的异常信息吃掉 也检查一下 不然我认为没有办法定位 |
8 guyeu 2020-01-17 18:35:18 +08:00 不要 catch throwable,全局设置一个默认的异常回调 ```java Thread.setDefaultUncaughtExceptionHandler((thread, throwable) -> {...}); ``` |
9 cheng6563 2020-01-17 20:43:17 +08:00 via Android 另外,如果出现 oom 错误被捕获了,错误处理里的代码又出现 oom,处理不当是可能线程挂掉又没有日志的。建议启动参数时配置当 oom 时报错并直接干掉整个进程。 |
10 btnokami 2020-01-18 06:42:38 +08:00 找个 Profiler 或者查查 thread dump 吧 |
12 gaius 2020-01-18 12:40:28 +08:00 via Android run 里面直接包 try catch,可以参考线程池 runWorker 里面是怎么写的 |
13 matepi 2020-01-18 12:58:13 +08:00 via iPhone @zhaorunze syserr 有配 logger 的话会有,但很多的 logger 配法都会把默认 out 和 err 丢掉。 |
14 alexgor 2020-01-19 04:34:09 +08:00 via Android 笑死 |