目录
原因:日志打印的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>