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 彩色日志 分类输出到不 ......
▶ 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>
最终效果如下:
© 著作权归作者所有,转载或内容合作请联系作者
问题来了,请问诸位你们项目中目前在使用logback还是log4j2呢?
● 【双11狂欢的背后】微服务注册中心如何承载大型系统的千万级访问?
本文由博客一文多发平台 openwrite 发布!
上一篇: Jquery开发电商网站实战(带源码)
下一篇: vue-基本动画