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

Java 线程会莫名其妙的消失

  •  
  •   burnbrid · 32 天前 · 1975 次点击
    这是一个创建于 32 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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