0
点赞
收藏
分享

微信扫一扫

SpringBoot2下log4j2和logback实现异步打印

Mhhao 2021-09-25 阅读 41

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>

注:异步打印日志,无法打印出具体的行数信息。

举报

相关推荐

0 条评论