当前位置:首页 > 科技  > 软件

解决 Java 打印日志吞异常堆栈的问题

来源: 责编: 时间:2023-09-18 21:40:35 425观看
导读前几天有同学找我查一个空指针问题,Java 打印日志时,异常堆栈信息被吞了,导致定位不到出问题的地方。现象捕获异常打印日志的代码类似这样:try { // ...} catch (Exception e) { log.error("系统异常 customerCode:

前几天有同学找我查一个空指针问题,Java 打印日志时,异常堆栈信息被吞了,导致定位不到出问题的地方。l1528资讯网——每日最新资讯28at.com

l1528资讯网——每日最新资讯28at.com

现象

捕获异常打印日志的代码类似这样:l1528资讯网——每日最新资讯28at.com

try {    // ...} catch (Exception e) {    log.error("系统异常 customerCode:{},data:{}", customerCode, data, e);    // ...}

查到的日志是这样的:l1528资讯网——每日最新资讯28at.com

2023-06-26 11:11:11.111 ERROR 1 --- [pool-1-thread-1] c.mazhuang.service.impl.TestServiceImpl  : 系统异常 customerCode:123,data:{"name":"mazhuang","age":18}java.lang.NullPointerException: null

异常堆栈丢了。l1528资讯网——每日最新资讯28at.com

分析

在之前的一篇文章里已经验证过这种写法是可以正常打印异常和堆栈信息的:AI 自动补全的这句日志能正常打印吗?l1528资讯网——每日最新资讯28at.com

再三确认代码写法没问题,纳闷之下只好搜索了一下关键词「Java异常堆栈丢失」,发现了这篇文章:Java异常堆栈丢失的现象及解决方法,这里面提到的问题与我们遇到的一样,而且给出了 Oracle 官方文档里的相关说明:l1528资讯网——每日最新资讯28at.com

https://www.oracle.com/java/technologies/javase/release-notes-introduction.htmll1528资讯网——每日最新资讯28at.com

The compiler in the server VM now provides correct stack backtraces for all “cold” built-in exceptions. For performance purposes, when such an exception is thrown a few times, the method may be recompiled. After recompilation, the compiler may choose a faster tactic using preallocated exceptions that do not provide a stack trace. To disable completely the use of preallocated exceptions, use this new flag: -XX:-OmitStackTraceInFastThrow.l1528资讯网——每日最新资讯28at.com

l1528资讯网——每日最新资讯28at.com

大致意思就是说,为了提高性能,JVM 会针对一些内建异常进行优化,在这些异常被某方法多次抛出时,JVM 可能会重编译该方法,这时候就可能会使用不提供堆栈信息的预分配异常。如果想要完全禁用预分配异常,可以使用 -XX:-OmitStackTraceInFastThrow 参数。l1528资讯网——每日最新资讯28at.com

了解到这个信息后,翻了翻从服务上次发版以来的这条日志,果然最早的十几次打印是有异常堆栈的,后面就没有了。l1528资讯网——每日最新资讯28at.com

解决方案

回溯历史日志,找到正常打印的堆栈信息,定位和解决问题;l1528资讯网——每日最新资讯28at.com

也可以考虑在 JVM 参数里加上 -XX:-OmitStackTraceInFastThrow 参数,禁用优化;l1528资讯网——每日最新资讯28at.com

本地复现

在本地写一个简单的程序复现一下:l1528资讯网——每日最新资讯28at.com

public class StackTraceInFastThrowDemo {    public static void main(String[] args) {        int count = 0;        boolean flag = true;        while (flag) {            try {                count++;                npeTest(null);            } catch (Exception e) {                int stackTraceLength = e.getStackTrace().length;                System.out.printf("count: %d, stacktrace length: %d%n", count, stackTraceLength);                if (stackTraceLength == 0) {                    flag = false;                }            }        }    }    public static void npeTest(Integer i) {        System.out.println(i.toString());    }}

不添加 -XX:-OmitStackTraceInFastThrow 作为 JVM 参数时,运行结果如下:l1528资讯网——每日最新资讯28at.com

...count: 5783, stacktrace length: 2count: 5784, stacktrace length: 2count: 5785, stacktrace length: 0Process finished with exit code 0

在我本机一般运行五六千次后,会出现异常堆栈丢失的情况。l1528资讯网——每日最新资讯28at.com

添加 -XX:-OmitStackTraceInFastThrow 作为 JVM 参数时,运行结果如下:l1528资讯网——每日最新资讯28at.com

...count: 3146938, stacktrace length: 2count: 3146939, stacktrace length: 2count: 3146940, stacktrace length: Process finished with exit code 137 (interrupted by signal 9: SIGKILL)

运行了几百万次也不会出现异常堆栈丢失的情况,手动终止程序。l1528资讯网——每日最新资讯28at.com

完整源码见:https://github.com/mzlogin/java-notes/blob/master/src/org/mazhuang/StackTraceInFastThrowDemo.javal1528资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-10425-0.html解决 Java 打印日志吞异常堆栈的问题

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Python中30个常见的内置函数使用讲解(一)

下一篇: 【Python入门】为什么这门编程语言如此受欢迎?

标签:
  • 热门焦点
  • 直屏旗舰来了 iQOO 12和K70 Pro同台竞技

    旗舰机基本上使用的都是双曲面屏幕,这就让很多喜欢直屏的爱好者在苦等一款直屏旗舰,这次,你们等到了。据博主数码闲聊站带来的最新爆料称,Redmi下代旗舰K70 Pro和iQOO 12两款手
  • 中兴AX5400Pro+上手体验:再升级 双2.5G网口+USB 3.0这次全都有

    2021年11月的时候,中兴先后发布了两款路由器产品,中兴AX5400和中兴AX5400 Pro,从产品命名上就不难看出这是隶属于同一系列的,但在外观设计上这两款产品可以说是完全没一点关系
  • 六大权益!华为8月服务日开启:手机免费贴膜、维修免人工费

    8月5日消息,一年一度的华为开发者大会2023(Together)日前在松山湖拉开帷幕,与此同时,华为8月服务日也式开启,到店可享六大专属权益。华为用户可在华为商城Ap
  • Rust中的高吞吐量流处理

    作者 | Noz编译 | 王瑞平本篇文章主要介绍了Rust中流处理的概念、方法和优化。作者不仅介绍了流处理的基本概念以及Rust中常用的流处理库,还使用这些库实现了一个流处理程序
  • CSS单标签实现转转logo

    转转品牌升级后更新了全新的Logo,今天我们用纯CSS来实现转转的新Logo,为了有一定的挑战性,这里我们只使用一个标签实现,将最大化的使用CSS能力完成Logo的绘制与动画效果。新logo
  • 一文看懂为苹果Vision Pro开发应用程序

    译者 | 布加迪审校 | 重楼苹果的Vision Pro是一款混合现实(MR)头戴设备。Vision Pro结合了虚拟现实(VR)和增强现实(AR)的沉浸感。其高分辨率显示屏、先进的传感器和强大的处理能力
  • 使用Webdriver-manager解决浏览器与驱动不匹配所带来自动化无法执行的问题

    1、前言在我们使用 Selenium 进行 UI 自动化测试时,常常会因为浏览器驱动与浏览器版本不匹配,而导致自动化测试无法执行,需要手动去下载对应的驱动版本,并替换原有的驱动,可能还
  • 一个注解实现接口幂等,这样才优雅!

    场景码猿慢病云管理系统中其实高并发的场景不是很多,没有必要每个接口都去考虑并发高的场景,比如添加住院患者的这个接口,具体的业务代码就不贴了,业务伪代码如下:图片上述代码有
  • 联想小新Pad Pro 12.6将要推出,搭载高通骁龙 870 处理器

    联想小新Pad Pro 12.6将于秋季新品会上推出,官方按照惯例直接在发布会前给出了机型的所有参数。联想小新 Pad Pro 12.6 将搭载高通骁龙 870 处理器,重量为 5
Top