V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
burnbrid
V2EX  ›  程序员

Java 线程会莫名其妙的消失

  •  
  •   burnbrid · 2020-01-17 16:23:53 +08:00 · 4998 次点击
    这是一个创建于 1763 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我们生产环境,总是有 JAVA 线程莫名其妙的消失,有没有什么软件可以看到 JVM 什么时候把这些线程回收了?或者可以找到证据来证明这个线程确实是被 JVM 回收了? 我们从日志上看,这个线程肯定是运行一半被回收了,但是找不到证据。各位大神怎么找证据?

    14 条回复    2020-01-19 04:34:09 +08:00
    wysnylc
        1
    wysnylc  
       2020-01-17 16:32:01 +08:00
    抛异常了而且你们捕获了但是没打印栈吧
    chendy
        2
    chendy  
       2020-01-17 16:36:18 +08:00
    线程不会无缘无故地消失,要么出异常了要么跑完了
    目测是异常处理不当丢信息了…
    awfe
        3
    awfe  
       2020-01-17 16:36:18 +08:00
    有异常了吧
    yumenawei
        4
    yumenawei  
       2020-01-17 16:37:54 +08:00
    我猜你们是用的默认的线程池,然后线程莫名没了。
    matepi
        5
    matepi  
       2020-01-17 16:39:18 +08:00
    刚好我的帖里谈到的。没有 catch Throwable,只 catch Exception 了?
    https://www.v2ex.com/t/638609
    Raymon111111
        6
    Raymon111111  
       2020-01-17 17:52:54 +08:00
    全局 try catch
    palmers
        7
    palmers  
       2020-01-17 18:13:33 +08:00
    给自己的线程定义名称 然后再排查 楼上说的异常信息吃掉 也检查一下 不然我认为没有办法定位
    guyeu
        8
    guyeu  
       2020-01-17 18:35:18 +08:00
    不要 catch throwable,全局设置一个默认的异常回调
    ```java
    Thread.setDefaultUncaughtExceptionHandler((thread, throwable) -> {...});
    ```
    cheng6563
        9
    cheng6563  
       2020-01-17 20:43:17 +08:00 via Android
    另外,如果出现 oom 错误被捕获了,错误处理里的代码又出现 oom,处理不当是可能线程挂掉又没有日志的。建议启动参数时配置当 oom 时报错并直接干掉整个进程。
    btnokami
        10
    btnokami  
       2020-01-18 06:42:38 +08:00
    找个 Profiler 或者查查 thread dump 吧
    zhaorunze
        11
    zhaorunze  
       2020-01-18 11:48:48 +08:00
    @matepi Error 不 catch 日志不会打印吗?
    gaius
        12
    gaius  
       2020-01-18 12:40:28 +08:00 via Android
    run 里面直接包 try catch,可以参考线程池 runWorker 里面是怎么写的
    matepi
        13
    matepi  
       2020-01-18 12:58:13 +08:00 via iPhone
    @zhaorunze syserr 有配 logger 的话会有,但很多的 logger 配法都会把默认 out 和 err 丢掉。
    alexgor
        14
    alexgor  
       2020-01-19 04:34:09 +08:00 via Android
    笑死
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5934 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 30ms · UTC 01:58 · PVG 09:58 · LAX 17:58 · JFK 20:58
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.