电子商务网站建设的目的是开展网络营销,做网站的公司利润,小兔自助建站系统,seo站长常用工具SpringBoot中日志的使用log4j2
1、log4j2介绍
Apache Log4j2 是对 Log4j 的升级#xff0c;它比其前身 Log4j 1.x 提供了重大改进#xff0c;并提供了 Logback 中可用的许多改
进#xff0c;同时修复了 Logback 架构中的一些问题#xff0c;主要有#xff1a; 异常处理…SpringBoot中日志的使用log4j2
1、log4j2介绍
Apache Log4j2 是对 Log4j 的升级它比其前身 Log4j 1.x 提供了重大改进并提供了 Logback 中可用的许多改
进同时修复了 Logback 架构中的一些问题主要有 异常处理在logback中Appender中的异常不会被应用感知到但是在log4j2中提供了一些异常处理机 制。 性能提升log4j2 相较于log4j 和 logback 都具有明显的性能提升有18倍性能提升后面会有官方测试的数 据。 自动重载配置参考了logback的设计当然会提供自动刷新参数配置最实用的就是我们在生产上可以动态 的修改日志的级别而不需要重启应用。 无垃圾机制log4j2 在大部分情况下都可以使用其设计的一套无垃圾机制【对象重用、内存缓冲】避免频 繁的日志收集导致的 jvm gc。
log4j、logback、log4j2都是一种日志具体实现框架所以既可以单独使用也可以结合slf4j一起搭配使用。
官网https://logging.apache.org/log4j/2.x
2、项目使用
2.1 pom依赖
springboot 默认使用的日志框架为 logback要想使用 log4j2需要从 spring-boot-starter-web 中排除对
spring-boot-starter-logging 依赖。
dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-web/artifactIdexclusions!--排除logback--exclusiongroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-logging/artifactId/exclusion/exclusions
/dependency引入Log4j2依赖
!--log4j2 依赖--
dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-log4j2/artifactId
/dependencyspring-boot-starter-log4j2 的依赖关系 上面的 log4j2 已经适配了 slf4j 日志门面内部依赖了slf4j、log4j。
SpringBoot 使用 log4j2 作为日志门面但是最终也是通过 slf4j 调用 logback。
完整的依赖
?xml version1.0 encodingUTF-8?
project xmlnshttp://maven.apache.org/POM/4.0.0 xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersionparentgroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-parent/artifactIdversion2.5.6/versionrelativePath//parentgroupIdcom.log/groupIdartifactIdspring-boot-log4j2/artifactIdversion0.0.1-SNAPSHOT/versionnamespring-boot-log4j2/namedescriptionspring-boot-log4j2/descriptionpropertiesjava.version1.8/java.version/propertiesdependenciesdependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-web/artifactIdexclusions!--排除logback--exclusiongroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-logging/artifactId/exclusion/exclusions/dependencydependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-test/artifactIdscopetest/scope/dependency!--log4j2 依赖--dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-log4j2/artifactId/dependency/dependenciesbuildpluginsplugingroupIdorg.springframework.boot/groupIdartifactIdspring-boot-maven-plugin/artifactId/plugin/plugins/build/project2.2 log4j2配置
创建log4j2.xml文件放在工程resources目录里。这样就可以不加任何配置。如果你需要指定配置
文件需要在Spring boot 配置文件application.yml中指定 logging.config 属性。
下面是一份比较详细的 log4j2.xml 配置文件
?xml version1.0 encodingUTF-8?
!-- 日志级别从低到高优先级为: ALL TRACE DEBUG INFO WARN ERROR FATAL OFF --
!-- configuration后面的status,这个用于设置log4j2自身内部的信息输出,可以不设置,当设置成trace时,你会看到log4j2内部各种详细输出 --
!--monitorInterval: 监视配置文件变化间隔时间,单位秒,Log4j2能够自动检测配置文件是否修改,同时更新配置 --
configuration monitorInterval5!-- 变量配置 --!-- 定义属性,在下方方便维护引用 --Properties!--当天文件保存目录,建议不要配置相对路径--property nameLOG_DIR./logs/property!--历史文件保存目录--property nameHISTORY_LOG_DIR./logs/history/property!--项目名称--property nameFILE_NAME valuelog4j2/!--如果当天日志文件大于100MB,则存档--property nameSPLIT_SIZE100MB/property!--文件保存个数这里的30说明可保留30个,即30天--property nameFILE_COUNT30/property!--interval属性用来指定多久滚动一次,默认是1 hour--property nameINTERVAL30/property!--输出日志的格式:%d表示日期时间,%thread表示线程名,%-5level级别从左显示5个字符宽度,%logger{50}表示logger名字最长50个字符,否则按照句点分割,%line表示行号,%msg日志消息,%n换行符--property nameLOG_PATTERN%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50}:(%line) - %msg%n/property/Properties!--先定义所有的appender附加器--appenders!--1、控制台输出配置--console nameConsole targetSYSTEM_OUT!--控制台只输出level及其以上级别的信息(onMatch),其他的直接拒绝(onMismatch)--!--ThresholdFilter levelinfo onMatchACCEPT onMismatchDENY/--filtersThresholdFilter levelINFO onMatchACCEPT onMismatchDENY//filters!--输出日志的格式--PatternLayout pattern${LOG_PATTERN}//console!-- 2、输出日志信息到文件存储 --!--文件存储文件设置--!--文件会打印出所有信息,这个log每次运行程序会自动清空,由append属性决定,适合临时测试用--File nameFileLog fileName${LOG_DIR}/test.log appendfalsePatternLayout pattern${LOG_PATTERN}//File!-- 3、输出日志信息滚动到文件存储 --!--fileName:文件存储路径及名称,可以是绝对路径或者相对路径,存储的永远是最新的日志信息--!--filePattern:当fileName指定的文件大小超过限制,就会根据此文件名规则新建存档目录与文件,同时将fileName文件中的内容剪切到存档文件中,如下配置,会新建存档路径 logs/history/log4j2-DEBUG-2021-03-26-1.log.gz --!-- 这个会打印出所有的debug级别的信息,每次大小超过size,则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档--!--以下只保存debug信息--RollingFile nameRollingFileDebug fileName${LOG_DIR}/debug.logfilePattern${HISTORY_LOG_DIR}/${FILE_NAME}-DEBUG-%d{yyyy-MM-dd}-%i.log.gz!--控制台只输出level级别的信息--!--LevelFilter leveldebug onMatchACCEPT onMismatchDENY/--!--onMatch和onMismatch都有三个属性值分别为Accept、DENY和NEUTRALonMatchACCEPT 表示匹配该级别及以上onMatchDENY 表示不匹配该级别及以上onMatchNEUTRAL 表示该级别及以上的,由下一个filter处理,如果当前是最后一个,则表示匹配该级别及以上onMismatchACCEPT 表示匹配该级别以下onMismatchNEUTRAL 表示该级别及以下的,由下一个filter处理,如果当前是最后一个,则不匹配该级别以下的onMismatchDENY 表示不匹配该级别以下的--filtersThresholdFilter levelINFO onMatchDENY onMismatchNEUTRAL/ThresholdFilter levelDEBUG onMatchACCEPT onMismatchDENY//filtersPatternLayout pattern${LOG_PATTERN}/Policies!--interval属性用来指定多久滚动一次,默认是1 hour--TimeBasedTriggeringPolicy interval${INTERVAL}/!--日志文件大小超过多少时进行存档--SizeBasedTriggeringPolicy size${SPLIT_SIZE}//Policies!-- DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件开始覆盖--DefaultRolloverStrategy max${FILE_COUNT}//RollingFile!--以下只保存info信息--RollingFile nameRollingFileInfo fileName${LOG_DIR}/info.logfilePattern${HISTORY_LOG_DIR}/${FILE_NAME}-INFO-%d{yyyy-MM-dd}-%i.log.gz!--控制台只输出level级别的信息--!--LevelFilter levelinfo onMatchACCEPT onMismatchDENY/--filtersThresholdFilter levelWARN onMatchDENY onMismatchNEUTRAL/ThresholdFilter levelINFO onMatchACCEPT onMismatchDENY//filtersPatternLayout pattern${LOG_PATTERN}/Policies!--interval属性用来指定多久滚动一次,默认是1 hour--TimeBasedTriggeringPolicy interval${INTERVAL}/!--日志文件大小超过多少时进行存档--SizeBasedTriggeringPolicy size${SPLIT_SIZE}//Policies!-- DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件开始覆盖--DefaultRolloverStrategy max${FILE_COUNT}//RollingFile!--以下只保存warn信息--RollingFile nameRollingFileWarn fileName${LOG_DIR}/warn.logfilePattern${HISTORY_LOG_DIR}/${FILE_NAME}-WARN-%d{yyyy-MM-dd}-%i.log.gz!--控制台只输出level级别的信息--!--LevelFilter levelwarn onMatchACCEPT onMismatchDENY/--filtersThresholdFilter levelERROR onMatchDENY onMismatchNEUTRAL/ThresholdFilter levelWARN onMatchACCEPT onMismatchDENY//filtersPatternLayout pattern${LOG_PATTERN}/Policies!--interval属性用来指定多久滚动一次,默认是1 hour--TimeBasedTriggeringPolicy interval${INTERVAL}/!--日志文件大小超过多少时进行存档--SizeBasedTriggeringPolicy size${SPLIT_SIZE}//Policies!-- DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件开始覆盖--DefaultRolloverStrategy max${FILE_COUNT}//RollingFile!--以下只保存error信息--RollingFile nameRollingFileError fileName${LOG_DIR}/error.logfilePattern${HISTORY_LOG_DIR}/${FILE_NAME}-ERROR-%d{yyyy-MM-dd}-%i.log.gz!--控制台只输出level级别的信息--!--LevelFilter levelerror onMatchACCEPT onMismatchDENY/--filtersThresholdFilter levelerror onMatchACCEPT onMismatchDENY//filtersPatternLayout pattern${LOG_PATTERN}/Policies!--interval属性用来指定多久滚动一次,默认是1 hour--TimeBasedTriggeringPolicy interval${INTERVAL}/!--日志文件大小超过多少时进行存档--SizeBasedTriggeringPolicy size${SPLIT_SIZE}//Policies!-- DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件开始覆盖--DefaultRolloverStrategy max${FILE_COUNT}//RollingFile!--以下保存api请求信息--RollingFile nameApiInfo fileName${LOG_DIR}/api.logfilePattern${HISTORY_LOG_DIR}/${FILE_NAME}-API-%d{yyyy-MM-dd}-%i.log.gzfiltersThresholdFilter levelinfo onMatchACCEPT onMismatchDENY//filtersPatternLayout pattern${LOG_PATTERN}/Policies!--interval属性用来指定多久滚动一次,默认是1 hour--TimeBasedTriggeringPolicy interval${INTERVAL}/!--日志文件大小超过多少时进行存档--SizeBasedTriggeringPolicy size${SPLIT_SIZE}//Policies!-- DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件开始覆盖--DefaultRolloverStrategy max${FILE_COUNT}//RollingFile!-- 整合elk --Socket nameLogstash host127.0.0.1 port4560 protocolTCPPatternLayout pattern${logPattern}//Socket/appenders!--1、root与logger是父子关系,没有特别定义logger的都默认为root。2、任何一个类只会和一个logger对应,要么是定义的logger,要么是root,判断的关键在于找到这个logger,然后判断这个logger的appender和level3、appender-ref用于引用上面定义好的appender日志追加器,只有引用了,上面的appender才能生效--!--Logger节点用来单独指定日志的形式,比如要为指定包下的class指定不同的日志级别等 --!--然后定义logger,只有定义了logger并引入的appender,appender才会生效--loggers!--过滤掉spring和mybatis的一些无用的DEBUG信息;也可以单独指定自己的某个包--!--以下包中ERROR级别以上日志在root中将被记录--!--logger nameorg.springframework levelERROR/loggerlogger nameorg.mybatis levelERROR/loggerlogger nameorg.hibernate levelERROR/loggerlogger nameorg.apache levelERROR/loggerlogger namecom.baomidou levelERROR/loggerlogger namecom.zaxxer levelERROR/loggerlogger namespringfox.documentation levelERROR/logger--!-- 控制该包下的日志等级 --!--com.log.controller包中的DEBUG以上信息在以下的appender中输出,additivity所有日志还要向控制台和allLog中输出--!--logger namecom.log.controller levelDEBUG additivitytrueappender-ref refRollingFileDebug/appender-ref refRollingFileInfo/appender-ref refRollingFileWarn/appender-ref refRollingFileError/appender-ref refConsole/appender-ref refFileLog//logger--!--过滤掉spring和mybatis的一些无用的DEBUG信息--logger nameorg.mybatis levelinfo additivityfalseAppenderRef refConsole//logger!--监控系统信息--!--若是additivity设为false,则子Logger只会在自己的appender里输出,而不会在父Logger的appender里输出 --Logger nameorg.springframework levelinfo additivityfalseAppenderRef refConsole//Logger!-- 控制整个项目的日志等级 --root levelinfoappender-ref refConsole/appender-ref refFileLog/appender-ref refRollingFileDebug/appender-ref refRollingFileInfo/appender-ref refRollingFileWarn/appender-ref refRollingFileError//root/loggers
/configuration基本上你拿上面的配置根据你自己的需要更改一下即可生效。
注意 windows 下 ${sys:user.home} 会将日志打印到用户目录下。
2.3 启动类
package com.log;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;SpringBootApplication
public class SpringBootLogApplication {public static void main(String[] args) {SpringApplication.run(SpringBootLogApplication.class, args);}}2.4 测试
package com.log;import com.log.controller.LogController;
import org.junit.jupiter.api.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.test.context.SpringBootTest;SpringBootTest
public class SpringBootLogApplicationTests {/*** 声明日志记录器对象(slf4j包)*/public static final Logger logger LoggerFactory.getLogger(LogController.class);Testvoid contextLoads() {logger.error(error);logger.warn(warn);logger.info(info);logger.debug(debug);logger.trace(trace);}
}执行输出
2023-11-19 10:46:45.238 [main] ERROR com.log.controller.LogController:(19) - error
2023-11-19 10:46:45.250 [main] WARN com.log.controller.LogController:(20) - warn
2023-11-19 10:46:45.250 [main] INFO com.log.controller.LogController:(21) - info查看生成的文件 由于设置了日志等级root levelinfo为info所以debug不会有输出。
2.5 使用Slf4j注解输出日志
lombok中的Slf4j 注解可以很方便的使用 org.slf4j.Logger 对象。
日常开发尽量使用Slf4j门面来处理日志尽量避免使用具体的日志框架。
引入依赖
!-- lombok --
dependencygroupIdorg.projectlombok/groupIdartifactIdlombok/artifactId
/dependency编写controller
package com.log.controller;import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;/*** author tom*/
Slf4j
RestController
RequestMapping(/logging)
public class LogController {GetMapping(/do)public String log() {log.error(error......);log.warn(warn......);log.info(info......);log.debug(debug......);log.trace(trace......);return log4j2;}
}2.6 测试
启动应用访问http://localhost:8080/logging/do 3、log4j2配置文件详解
要想使 log4j2 配置生效需要在 resources 目录下新建 log4j2.xmlspringboot 会自动找到配置文件并加载。
3.1 日志级别
log4j2共分8个日志级别按从低到高排列为ALL TRACE DEBUG INFO WARN ERROR FATAL OFF
ALL: 最低等级日志级别输出所有日志
TRACE: 追踪日志如程序启动进程日志
DEBUG: 程序调试信息
INFO: 应用程序提示信息
WARN: 告警信息
ERROR: 程序报错信息
FATAL: 程序出错导致应用程序退出
OFF: 关闭日志设置应用程序的日志级别后将输出该级别及以上的日志。如设置日志级别为INFO那么程序会输出INFO、
WARN、ERROR及FATAL日志。
3.2 monitorInterval
监视配置文件变化间隔时间。如设置为30表示每隔30s程序会自动检测配置文件是否修改如果修改就更新
配置文件。
3.3 properties
定义属性方便在配置文件中引用。我们在这配置了 LOG_DIR、HISTORY_LOG_DIR、FILE_NAME、SPLIT_SIZE、
FILE_COUNT、INTERVAL 及 LOG_PATTERN 属性。
LOG_DIR: 日志输出目录
HISTORY_LOG_DIR: 日志输出历史目录
FILE_NAME: 日志文件的名字
SPLIT_SIZE: 日志存档临界值,如果当天日志大于临界值,则存档,在这配置为100M
FILE_COUNT: 存档文件个数,在这里配置为30,相当于保留最近30天的日志记录
INTERVAL: 用来指定多久滚动一次
LOG_PATTERN: 日志输出格式3.4 appenders
定义一系列的日志输出可输出至控制台或者文件中。主要有三种日志输出方式 Console定义输出至控制台的方式 File定义输出至文件的方式 RollingFile定义输出至文件的方式但会以一定的策略删除旧日志文件并创建新的日志文件 三种方式有共同的子节点。
3.4.1filters
定义日志输出等级。
如果想输出某个等级及其以上的日志可做如下配置
filtersThresholdFilter levelINFO onMatchACCEPT onMismatchDENY /
/filters以上配置过滤INFO级别及其以上的日志。
如果想单独输出某个等级的日志可做如下配置
filtersThresholdFilter levelINFO onMatchDENY onMismatchNEUTRAL /ThresholdFilter levelDEBUG onMatchACCEPT onMismatchDENY /
/filters以上配置只过滤DEBUG日志INFO及其以上等级的日志将被拒绝。
3.4.2 Console日志输出
定义日志输出至控制台主要属性有name、target、filters和PatternLayout。
name: 自己定义
target: 一般配置为SYSTEM_OUT,即将日志通过System.out输出
filters: 定义日志输出等级,这里配置等级为INFO,即INFO及以上等级的日志输出到控制台
PatternLayout: 定义日志输出格式3.4.3 File日志输出
定义日志输出至文件示例配置如下
File namefileLog fileName${logDir}/file.log appendtruefiltersThresholdFilter levelDEBUG onMatchACCEPT onMismatchDENY//filtersPatternLayout pattern${logPattern} /
/File主要属性和子节点有name、fileName、append、filters和PatternLayout。
fileName定义输出文件名append当为true时新增日志将被追加至文件末尾如果为false那么新日志将覆盖旧日志
3.4.4 RollingFile日志输出
也是定义日志输出至文件不同的是RollingFile可以定义日志文件存档策略。比如按照时间存档每天备份一次
最大存档30天等等。
!--以下只保存info信息--
RollingFile nameRollingFileInfo fileName${LOG_DIR}/info.logfilePattern${HISTORY_LOG_DIR}/${FILE_NAME}-INFO-%d{yyyy-MM-dd}-%i.log.gz!--控制台只输出level级别的信息--!--LevelFilter levelinfo onMatchACCEPT onMismatchDENY/--filtersThresholdFilter levelWARN onMatchDENY onMismatchNEUTRAL/ThresholdFilter levelINFO onMatchACCEPT onMismatchDENY//filtersPatternLayout pattern${LOG_PATTERN}/Policies!--interval属性用来指定多久滚动一次,默认是1 hour--TimeBasedTriggeringPolicy interval${INTERVAL}/!--日志文件大小超过多少时进行存档--SizeBasedTriggeringPolicy size${SPLIT_SIZE}//Policies!-- DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件开始覆盖--DefaultRolloverStrategy max${FILE_COUNT}/
/RollingFile主要属性和子节点有name、fileName、filePattern、filters、PatternLayout、Policies、
TimeBasedTriggeringPolicy、SizeBasedTriggeringPolicy 和 DefaultRolloverStrategy。
fileName: 定义现在日志输出文件名
filePattern: 定义历史日志文件名格式
filters: 以上只输出debug日志
Policies: 定义日志输出策略
TimeBasedTriggeringPolicy: 指定多长时间触发日志备份策略这里默认为一天,还可以设置interval和modulate属性
SizeBasedTriggeringPolicy: 指定日志文件多大时触发日志备份策略这里设置为100MB,即如果当天日志一次超过100MB备份为DEBUG-2023-05-02-1.log;如果再次超过100MB则备份为DEBUG-2023-05-02-2.log
DefaultRolloverStrategy: 设置日志文档存档个数max指定能保存的文件个数,超过后之前的文件将被删除3.4.5 Socket日志输出
定义日志输出至数据库或者其它日志管理系统如elk等。
!-- 整合elk --
Socket nameLogstash host127.0.0.1 port4560 protocolTCPPatternLayout pattern${logPattern}/
/Socket以上定义日志输出至127.0.0.1:4560服务器也就是我本地创建的elk日志管理系统。
3.5 loggers
所有在 appenders 里定义的 appender 都需要在 logger 下引用否则 appender 的配置就不会生效。
如果要过滤掉一些 debug 信息可以在 logger 中屏蔽掉如下屏蔽掉 org.mybatis 中 info 级别以下的日志
logger nameorg.mybatis levelinfo additivityfalseAppenderRef refConsole/
/logger设置项目中的日志输出至指定的文件并且在控制台中输出配置如下
logger namecom.log.controller levelDEBUG additivitytrueappender-ref refRollingFileDebug/appender-ref refRollingFileInfo/appender-ref refRollingFileWarn/appender-ref refRollingFileError/appender-ref refConsole/appender-ref refFileLog/
/loggerroot 节点为兜底操作所有在 appenders 中配置的但没有在其它 logger 中输出的都会在 root 的 logger 中
输出。
root levelinfoappender-ref refConsole/appender-ref refFileLog/appender-ref refRollingFileDebug/appender-ref refRollingFileInfo/appender-ref refRollingFileWarn/appender-ref refRollingFileError/
/root4、log4j与log4j2的不同配置
log4j与log4j2的配置文件中的属性有所不同具体请参考
https://logging.apache.org/log4j/2.x/manual/migration.html
5、log4j2的其它功能
5.1 占位符
使用{}占位符格式化参数。
package com.log;import com.log.controller.LogController;
import org.apache.logging.log4j.LogManager;
import org.junit.jupiter.api.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.test.context.SpringBootTest;SpringBootTest
public class SpringBootLogApplicationTests1 {/*** 声明日志记录器对象(slf4j包)*/public static final Logger logger LoggerFactory.getLogger(LogController.class);Testvoid contextLoads() {String paramspringboot 课程;logger.info(请求参数{},结果{},param,hello slf4j);}}输出
2023-11-19 14:36:44.293 [main] INFO com.log.controller.LogController:(21) - 请求参数springboot 课程,结果hello slf4j5.2 String.format的形式格式化参数
log4j2 中除了支持{}的参数占位符还支持String.format的形式。
注意如果想使用String.format的形式需要使用LogManager.getFormatterLogger。
package com.log;import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;SpringBootTest
public class SpringBootLogApplicationTests2 {// 使用的是org.apache.logging.log4j包public static Logger formatterLogger LogManager.getFormatterLogger(SpringBootLogApplicationTests2.class);Testvoid contextLoads() {formatterLogger.info(Integer.MAX_VALUE %d, Integer.MAX_VALUE);}}输出
2023-11-19 14:40:55.730 [main] INFO MyLogger:(15) - Integer.MAX_VALUE 21474836475.3 使用logger.printf格式化参数
log4j2 的 Logger 接口中还有一个 printf 方法无需创建LogManager.getFormatterLogger就可以使用
String.format的形式。
package com.log;import org.apache.logging.log4j.Level;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;SpringBootTest
public class SpringBootLogApplicationTests3 {// 使用的是org.apache.logging.log4j包public static Logger logger LogManager.getLogger(SpringBootLogApplicationTests3.class);Testvoid contextLoads() {logger.printf(Level.INFO, Integer.MAX_VALUE %d, Integer.MAX_VALUE);}
}输出
2023-11-19 14:46:17.133 [main] INFO MyLogger:(18) - Integer.MAX_VALUE 21474836475.4 惰性打日志(lazy logging)
package com.log;import com.log.controller.LogController;
import org.junit.jupiter.api.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.test.context.SpringBootTest;SpringBootTest
public class SpringBootLogApplicationTests4 {/*** 声明日志记录器对象(slf4j包)*/public static final Logger logger LoggerFactory.getLogger(LogController.class);Testvoid contextLoads() {if (logger.isInfoEnabled()) {String param springboot 课程;logger.info(请求参数{},结果{}, param, hello slf4j);}}
}输出
2023-11-19 14:49:30.652 [main] INFO com.log.controller.LogController:(21) - 请求参数springboot 课程,结果hello slf4j