Spring Boot 日志处理你还在用Logback?

2022-10-13,,,,

▶ log4j2 性能

  • https://logging.apache.org/log4j/2.x/performance.html

spring boot 依赖与配置

maven 依赖

<!-- web -->
        <dependency>
            <groupid>org.springframework.boot</groupid>
            <artifactid>spring-boot-starter-web</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>

        <!-- log4j2 异步支持 -->
        <dependency>
            <groupid>com.lmax</groupid>
            <artifactid>disruptor</artifactid>
            <version>3.3.6</version>
        </dependency>

xml 配置 resources/log4j2.xml

  • 混合 sync/async
  • 彩色日志
  • 分类输出到不同文件
  • 自动压缩日志文件并归档
<?xml version="1.0" encoding="utf-8"?>
<!-- configuration后面的status,这个用于设置log4j2自身内部的信息输出,可以不设置,当设置成trace时,
     你会看到log4j2内部各种详细输出。可以设置成off(关闭) 或 error(只输出错误信息)。
     30s 刷新此配置
-->
<configuration status="warn" monitorinterval="30">

    <!-- 日志文件目录、压缩文件目录、日志格式配置 -->
    <properties>
        <property name="filename">/users/admin/code/log</property>
        <property name="filegz">/users/admin/code/log/7z</property>
        <property name="pid">????</property>
        <property name="log_pattern">%clr{%d{yyyy-mm-dd hh:mm:ss.sss}}{faint} %clr{%5p} %clr{${sys:pid}}{magenta} %clr{---}{faint} %clr{[%15.15t]}{faint} %clr{%-40.40c{1.}}{cyan} %clr{:}{faint} %m%n%xwex</property>
    </properties>

    <appenders>
        <!-- 输出控制台日志的配置 -->
        <console name="console" target="system_out">
            <!--控制台只输出level及以上级别的信息(onmatch),其他的直接拒绝(onmismatch)-->
            <thresholdfilter level="debug" onmatch="accept" onmismatch="deny"/>
            <!-- 输出日志的格式 -->
            <patternlayout pattern="${log_pattern}"/>
        </console>

        <!-- 打印出所有的信息,每次大小超过size,则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档 -->
        <rollingrandomaccessfile name="infofile" filename="${filename}/web-info.log" immediateflush="false"
                                    filepattern="${filegz}/$${date:yyyy-mm}/%d{yyyy-mm-dd}-%i.web-info.gz">
            <patternlayout pattern="${log_pattern}"/>

            <policies>
                <sizebasedtriggeringpolicy size="20 mb"/>
            </policies>

            <filters>
                <!-- 只记录info和warn级别信息 -->
                <thresholdfilter level="error" onmatch="deny" onmismatch="neutral"/>
                <thresholdfilter level="info" onmatch="accept" onmismatch="deny"/>
            </filters>

            <!-- 指定每天的最大压缩包个数,默认7个,超过了会覆盖之前的 -->
            <defaultrolloverstrategy max="50"/>
        </rollingrandomaccessfile>

        <!-- 存储所有error信息 -->
        <rollingrandomaccessfile name="errorfile" filename="${filename}/web-error.log" immediateflush="false"
                                    filepattern="${filegz}/$${date:yyyy-mm}/%d{yyyy-mm-dd}-%i.web-error.gz">
            <patternlayout pattern="${log_pattern}"/>

            <policies>
                <sizebasedtriggeringpolicy size="50 mb"/>
            </policies>

            <filters>
                <!-- 只记录error级别信息 -->
                <thresholdfilter level="error" onmatch="accept" onmismatch="deny"/>
            </filters>

            <!-- 指定每天的最大压缩包个数,默认7个,超过了会覆盖之前的 -->
            <defaultrolloverstrategy max="50"/>
        </rollingrandomaccessfile>
    </appenders>

    <!-- mixed sync/async -->
    <loggers>
        <root level="debug" includelocation="true">
            <appenderref ref="console"/>
            <appenderref ref="infofile"/>
            <appenderref ref="errorfile"/>
        </root>

        <asyncroot level="debug" includelocation="true">
            <appenderref ref="console"/>
            <appenderref ref="infofile"/>
            <appenderref ref="errorfile"/>
        </asyncroot>
    </loggers>

</configuration>

最终效果如下:

© 著作权归作者所有,转载或内容合作请联系作者

问题来了,请问诸位你们项目中目前在使用logback还是log4j2呢?

● 【双11狂欢的背后】微服务注册中心如何承载大型系统的千万级访问?

● spring boot 新一代监控你该这么玩

● spring boot 异常处理

● spring boot 配置 - 配置信息加密

● 拒绝黑盒应用-spring boot 应用可视化监控

● 并发bug之源有三,请睁大眼睛看清它们

本文由博客一文多发平台 openwrite 发布!

《Spring Boot 日志处理你还在用Logback?.doc》

下载本文的Word格式文档,以方便收藏与打印。