我们生产环境,总是有 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
我猜你们是用的默认的线程池,然后线程莫名没了。
|
5
matepi 2020-01-17 16:39:18 +08:00
刚好我的帖里谈到的。没有 catch Throwable,只 catch Exception 了?
https://www.v2ex.com/t/638609 |
6
Raymon111111 2020-01-17 17:52:54 +08:00
全局 try catch
|
7
palmers 2020-01-17 18:13:33 +08:00
给自己的线程定义名称 然后再排查 楼上说的异常信息吃掉 也检查一下 不然我认为没有办法定位
|
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
笑死
|