1. logback实现异步日志打印
SpringBoot2.x默认的日志工具为logback
,实现异步打印日志,只需要修改配置文件:
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<springProperty scope="context" name="logPath" source="log.out.path" defalutValue="/app/test.log"/>
<!-- %m输出的信息,%p日志级别,%t线程名,%d日期,%c类的全名,%i索引【从数字0开始递增】,,, -->
<!-- appender是configuration的子节点,是负责写日志的组件。 -->
<!-- ConsoleAppender:把日志输出到控制台 -->
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<!-- <pattern>%d %p [%r] [%t] [%X{traceRootId}] (%file:%line\): %m%n</pattern>-->
<pattern>%d %p [%r] [%t] [%X{traceRootId}] (%c\): %m%n</pattern>
<!-- 控制台也要使用UTF-8,不要使用GBK,否则会中文乱码 -->
<charset>UTF-8</charset>
</encoder>
</appender>
<!-- RollingFileAppender:滚动记录文件,先将日志记录到指定文件,当符合某个条件时,将日志记录到其他文件 -->
<!-- 以下的大概意思是:1.先按日期存日志,日期变了,将前一天的日志文件名重命名为XXX%日期%索引,新的日志仍然是demo.log -->
<!-- 2.如果日期没有发生变化,但是当前日志的文件大小超过1KB时,对当前日志进行分割 重命名-->
<appender name="cleanLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>ERROR</level>
</filter>
<File>log/catalina.out</File>
<!-- rollingPolicy:当发生滚动时,决定 RollingFileAppender 的行为,涉及文件移动和重命名。 -->
<!-- TimeBasedRollingPolicy: 最常用的滚动策略,它根据时间来制定滚动策略,既负责滚动也负责出发滚动 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 活动文件的名字会根据fileNamePattern的值,每隔一段时间改变一次 -->
<!-- 文件名:log/demo.2017-12-05.0.log -->
<fileNamePattern>${logPath}/log/catalina.out.%d{yyyy_MM_dd_HH}</fileNamePattern>
<!-- 每产生一个日志文件,该日志文件的保存期限为30天 -->
<maxHistory>30</maxHistory>
</rollingPolicy>
<encoder>
<!-- pattern节点,用来设置日志的输入格式 -->
<pattern>
%d %p [%t] [%X{traceRootId}] (%file:%line\): %m%n
</pattern>
<!-- 记录日志的编码:此处设置字符集 - -->
<charset>UTF-8</charset>
</encoder>
</appender>
<!-- 控制台输出日志级别 -->
<!-- 异步输出 -->
<appender name="ASYNC-STDOUT" class="ch.qos.logback.classic.AsyncAppender">
<!-- 不丢失日志.默认的,如果队列的80%已满,则会丢弃TRACT、DEBUG、INFO级别的日志 -->
<discardingThreshold>0</discardingThreshold>
<!-- 更改默认的队列的深度,该值会影响性能.默认值为256 -->
<queueSize>256</queueSize>
<!-- 添加附加的appender,最多只能添加一个 -->
<appender-ref ref="STDOUT"/>
</appender>
<root level="INFO">
<appender-ref ref="ASYNC-STDOUT"/>
</root>
</configuration>
2. log4j2实现异步日志打印
首先需要使用log4j2
替换logback
,并且log4j2性能远优于logback。
修改pom:
<dependencies>
<!--SpringBoot移除默认的logback依赖-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<!--引入log4j2的依赖-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
<!--支持AsyncLogger模式需要引入的依赖-->
<dependency>
<groupId>com.lmax</groupId>
<artifactId>disruptor</artifactId>
<version>3.4.2</version>
</dependency>
</dependencies>
推荐阅读:
Log4j2中的同步日志与异步日志
使用AsyncLogger
模式来实现日志的异步打印(性能更优)。
配置文件:(rosources目录下)log4j2-spring.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<!--日志级别以及优先级排序: OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL -->
<!--Configuration后面的status,这个用于设置log4j2自身内部的信息输出,可以不设置,
当设置成trace时,你会看到log4j2内部各种详细输出-->
<!--monitorInterval:Log4j能够自动检测修改配置 文件和重新配置本身,设置间隔秒数-->
<configuration monitorInterval="60">
<Properties>
<property name="log_pattern">%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %t %c - %m%n</property>
<property name="log.charset">UTF-8</property>
<property name="log.path">log/</property>
<property name="every_file_size">500 MB</property>
</Properties>
<appenders>
<console name="stdout" target="SYSTEM_OUT">
<PatternLayout pattern="${log_pattern}" charset="${log.charset}"/>
</console>
<RollingRandomAccessFile name="file"
fileName="${log.path}tell_web.log"
filePattern="${log.path}tell_web.%d{yyyy-MM-dd}_%i.log.gz">
<PatternLayout pattern="${log_pattern}" charset="${log.charset}"/>
<Policies>
<TimeBasedTriggeringPolicy interval="1"/>
<SizeBasedTriggeringPolicy size="${every_file_size}"/>
</Policies>
<DefaultRolloverStrategy fileIndex="nomax">
<Delete basePath="${log.path}" maxDepth="1">
<IfFileName glob="*.log.gz"/>
<IfLastModified age="P30D"/>
</Delete>
</DefaultRolloverStrategy>
</RollingRandomAccessFile>
<RollingRandomAccessFile name="error"
fileName="${log.path}tell_web_error.log"
filePattern="${log.path}tell_web_error.%d{yyyy-MM-dd}_%i.log.gz">
<Filters>
<ThresholdFilter level="ERROR" onMatch="ACCEPT" onMismatch="DENY"/>
</Filters>
<PatternLayout pattern="${log_pattern}" charset="${log.charset}"/>
<Policies>
<TimeBasedTriggeringPolicy interval="1"/>
<SizeBasedTriggeringPolicy size="${every_file_size}"/>
</Policies>
<DefaultRolloverStrategy fileIndex="nomax">
<Delete basePath="${log.path}" maxDepth="1">
<!--备份文件为压缩包gz格式-->
<IfFileName glob="*.log.gz"/>
<!--配置失效时间-->
<IfLastModified age="P30D"/>
</Delete>
</DefaultRolloverStrategy>
</RollingRandomAccessFile>
</appenders>
<loggers>
<Root level="info">
<AppenderRef ref="stdout"/>
<AppenderRef ref="file"/>
<AppenderRef ref="error"/>
</Root>
<!--业务包下使用异步打印-->
<AsyncLogger name="com.tellme" level="info" includeLocation="false" additivity="false">
<appender-ref ref="stdout"/>
<AppenderRef ref="file"/>
<AppenderRef ref="error"/>
</AsyncLogger>
<!-- <AsyncLogger name="org.springframework" level="info" includeLocation="false" additivity="false">-->
<!-- <appender-ref ref="stdout"/>-->
<!-- <AppenderRef ref="file"/>-->
<!-- <AppenderRef ref="error"/>-->
<!-- </AsyncLogger>-->
<AsyncLogger name="com.alibaba" level="info" includeLocation="false" additivity="false">
<appender-ref ref="stdout"/>
<AppenderRef ref="file"/>
<AppenderRef ref="error"/>
</AsyncLogger>
<AsyncLogger name="com.netflix" level="info" includeLocation="false" additivity="false">
<appender-ref ref="stdout"/>
<AppenderRef ref="file"/>
<AppenderRef ref="error"/>
</AsyncLogger>
<!--关闭nacos输出配置到日志中-->
<AsyncLogger name="com.alibaba.cloud.nacos" level="warn" includeLocation="false" additivity="false">
</AsyncLogger>
</loggers>
</configuration>
注:异步打印日志,无法打印出具体的行数信息。