前言
最近在对项目中的一些接口进行压测,但是压测的结果并不是很理想,接口的响应时间下不来,而吞吐量也迟迟上不去,分析代码发现LogBack记录日志花费了较多的时间,LogBack默认采用同步的方式记录日志,高并发下这也导致一定的线程运行延迟。因此对接口响应时间有特殊要求的接口决定采用异步记录日志的方式。
LogBack日志同步记录更改为异步记录并不需要更改原配置,只需要在原配置的基础上再增加一下配置。
LogBack异步记录
先把我的配置贴出来
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true">
<!-- 日志编码 -->
<property name="CHARSET" value="utf-8"></property>
<!-- 日志记录格式 -->
<property name="ERROR_PATTERN"
value="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L-%msg%n" />
<property name="INFO_PATTERN"
value="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L-%msg%n" />
<!-- 日志记录器,日期滚动记录 -->
<appender name="FILEINFO"
class="ch.qos.logback.core.