业务代码异常却日志缺失,如何排查?

业务代码异常却日志缺失,如何排查?

业务代码异常,日志却不见了?高效排查指南

开发过程中,业务代码抛出异常,但日志系统却“沉默”的情况时有发生。本文将结合实例,分析可能原因并提供高效的排查策略。

案例代码:

以下代码片段展示了一个嵌套try-catch块的场景:

try {    List plans = planService.lambdaQuery()            .eq(Plan::getYn, YnEnum.YES.getLabel())            .eq(Plan::getStatus, Plan.Status.DONE.getCode())            .isNotNull(Plan::getPId)            .list();    List<List> partition = Lists.partition(plans, 5);    partition.forEach(planList -> {        try {            // 业务代码1 (潜在异常点)        } catch (Exception exception) {            log.error("报错信息1:", exception); // 内层异常捕获        }    });} catch (Exception exception) {    log.error("报错信息2:", exception); // 外层异常捕获} finally {    log.info("释放requestId[{}]的锁", requestId);    Redis.unlock(Module.REFRESH_PROMOTE, workerLockKey, requestId);}

登录后复制

问题: “业务代码1”可能抛出异常,但“报错信息1”日志缺失。

分析:

代码采用双层try-catch结构。如果“业务代码1”抛出异常,内层catch块捕获并记录“报错信息1”。 如果内层catch处理异常后程序继续执行,外层catch不会执行,导致“报错信息2”也不输出。因此,日志缺失可能源于日志记录配置问题。例如:

日志级别设置过高: 日志系统可能只记录ERROR级别以上日志,而log.error的实际级别被配置为WARN或INFO。日志输出目标错误: 日志文件路径配置错误,或日志系统无法写入目标文件。日志系统故障: 日志系统本身出现问题,导致日志无法记录。

排查步骤:

验证异常是否存在: 首先,务必确认“业务代码1”是否真的抛出异常。通过调试模式运行代码,观察异常堆栈信息。如果异常存在,则继续下一步。

检查日志配置:

日志级别: 检查日志配置文件(例如logback.xml或log4j.properties),确保log.error的级别设置为ERROR或更低级别(例如DEBUG)。输出目标: 验证日志文件路径是否正确,文件是否存在,是否有足够的磁盘空间。检查日志系统是否正确配置,例如是否正确配置了Appender。日志轮转策略: 检查日志轮转策略是否导致日志文件过早被删除或覆盖。

检查日志系统: 如果日志配置正确,但日志仍然缺失,则可能存在日志系统本身的问题。检查日志系统的运行状态,查看是否有错误日志,尝试重启日志系统。

监控系统: 一些监控系统可以捕获未被日志系统记录的异常。检查监控系统是否有相关告警。

代码审查: 仔细检查“业务代码1”及周围代码,确认异常是否被意外吞没(例如,catch块中没有log.error语句,或catch块中存在return语句)。

异常类型: 某些异常类型可能被JVM或应用服务器自动处理,未记录到日志中。检查JVM或应用服务器的日志,查看是否有相关信息。

通过以上步骤,系统地排查日志缺失问题,并找到根本原因。 记住,先验证异常的存在,再检查日志配置,最后才是日志系统本身。

以上就是业务代码异常却日志缺失,如何排查?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3246724.html

(0)
上一篇 2025年4月2日 14:23:19
下一篇 2025年4月2日 14:23:28

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 15个Java线程并发面试题和答案

    1. 现在有线程 T1、T2 和 T3。你如何确保 T2 线程在 T1 之后执行,并且 T3 线程在 T2 之后执行? 这个线程面试题通常在第一轮面试或电话面试时被问到,这道多线程问题为了测试面试者是否熟悉 join 方法的概念。答案也非常…

    2025年5月3日
    000
  • java面试题最容易犯错的8道

    1. static 和 final 的用法 static 的作用从三个方面来谈,分别是静态变量、静态方法、静态类。 静态变量:声明为 static 的静态变量实质上就是全局变量,当声明一个对象时,并不产生static 变量的拷贝,而是该类所…

    2025年5月3日
    000
  • Person p = new Person();在内存中做了哪些事情?

    Person p = new Person();在内存中做了哪些事情? 将Person.class文件加载进内存中。 如果p定义在主方法中,那么,就会在栈空间开辟一个变量空间p。 在堆内存给对象分配空间。 对对象中的成员进行默认初始化。 对…

    2025年5月3日
    000
  • 2020年JAVA最常见面试题汇总(收藏)

    java基础以及多个“比较” 1.collections.sort排序内部原理 在Java 6中Arrays.sort()和Collections.sort()使用的是MergeSort,而在Java 7中,内部实现换成了TimSort,其…

    2025年5月3日
    000
  • 9道常见的java笔试选择题

    1.关于Java编译,下面哪一个正确()(选择一项) A.Java程序经编译后产生machine code B.Java程序经编译后会生产byte code C.Java程序经编译后会产生DLL 立即学习“Java免费学习笔记(深入)”; …

    2025年5月3日
    000
  • java最新基础知识面试题

    java最新基础知识面试题 1、static关键字什么意思?java中是否可以覆盖一个private或者是static的方法? “static”表明一个成员变量或者是成员方法可以在没有所属类的实例变量的情况下访问。 java中static方…

    2025年5月3日
    000
  • java内存溢出面试题

    引起内存溢出的原因有很多种,常见的有以下几种: 内存中加载的数据量过于庞大,如一次从数据库取出过多数据; 集合类中有对对象的引用,使用完后未清空,使得JVM不能回收; 代码中存在死循环或循环产生过多重复的对象实体; 立即学习“Java免费学…

    2025年5月3日
    000
  • Java中高级面试题(附答案)

    1、redis如何跟本地数据同步? 程序实现mysql更新、添加、删除就会同步操作redis 程序查询redis,不存在就查询mysql,自动保存redis 2、redis几种数据结构? set、list、hash、string、zset …

    2025年5月3日
    000
  • java gc 面试题及答案(1~5题)

    1、既然有GC机制,为什么还会有内存泄露的情况? 理论上Java因为有垃圾回收机制(GC)不会存在内存泄露问题(这也是Java被广泛使用于服务器端编程的一个重要原因)。然而在实际开发中,可能会存在无用但可达的对象,这些对象不能被GC回收,因…

    2025年5月3日
    000
  • java笔试常见的选择题

    1.已知表达式int m[] = {0,1,2,3,4,5,6}; 下面那个表达式的值与数组的长度相等() A m.length() B. m.length C. m.length()+1 立即学习“Java免费学习笔记(深入)”; D. …

    2025年5月3日
    000

发表回复

登录后才能评论