欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-06-23 22:45:03
▶ Log4j2 性能 "https://logging.apache.org/log4j/2.x/performance.html" ▶ Spring Boot 依赖与配置 Maven 依赖 XML 配置 resources/log4j2.xml 混合 sync/async 彩色日志 分类输出到不 ......

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

▶ log4j2 性能

▶ 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>

最终效果如下:

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

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

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

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

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

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

spring boot 异常处理

spring boot 配置 - 配置信息加密

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

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

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

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