logback打印日志不显示具体的信息,显示问号

本文探讨了在使用ch.qos.logback.classic.AsyncAppender时,日志中%line字段显示为问号而非实际行号的问题。通过调整配置,新增<includeCallerData>true</includeCallerData>,成功解决了AsyncAppender不携带堆栈信息的默认行为,实现了日志行号的正确输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

表象:

原因:日志打印的Appender是使用的ch.qos.logback.classic.AsyncAppender

正确配置


表象:

配置:<Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{68} %line - %msg%n </Pattern>

日志体现:

//配置
<Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{68} %line - %msg%n
            </Pattern>
//日志
2019-10-28 10:00:00.597 [DubboServerHandler-thread-187] INFO  c.d.h.o.s.s.i.Test ? - arguments: batchOrderId=1484523235803393, pageDto={"offset":0,"pageNum":1,"pageSize":50,"totalCount":0}

yyyy-MM-dd HH:mm:ss.SSS:2019-10-28 10:00:00.597
[%thread]:[DubboServerHandler-thread-187]
%-5level:INFO 
%logger{68}:c.d.h.o.s.s.i.Test
%line:?
%msg:arguments: batchOrderId=1484523235803393, pageDto={"offset":0,"pageNum":1,"pageSize":50,"totalCount":0}

发现%line 输出的是?而不是想要的行数

原因:日志打印的Appender是使用的ch.qos.logback.classic.AsyncAppender

<!-- file asynch appender -->
    <appender name="fileAsyncInfoAppender" class="ch.qos.logback.classic.AsyncAppender">
        <!-- 不丢失日志.默认的,如果队列的80%已满,则会丢弃TRACT、DEBUG、INFO级别的日志 -->
        <discardingThreshold>0</discardingThreshold>
        <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
        <queueSize>512</queueSize>

        <appender-ref ref="orderServerAppender"/>
    </appender>

上面是原有的配置,查找资料发现AsyncAppender默认是不携带堆栈信息的

截图传送门

源码层面分析:ch.qos.logback.classic.AsyncAppender

这个方法获取的是栈堆信息

继续往下跟进:终于找到真相所在

正确配置

    <appender name="fileAsyncInfoAppender" class="ch.qos.logback.classic.AsyncAppender">
        <!-- 不丢失日志.默认的,如果队列的80%已满,则会丢弃TRACT、DEBUG、INFO级别的日志 -->
        <discardingThreshold>0</discardingThreshold>
        <!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
        <queueSize>512</queueSize>
        <!-- 新增这行为了打印栈堆信息 -->
        <includeCallerData>true</includeCallerData>
        <appender-ref ref="orderServerAppender"/>
    </appender>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值