springboot增加slf4j
参考:https://blog.csdn.net/qq_27706119/article/details/104977666(主要)
https://www.liaoxuefeng.com/wiki/1252599548343744/1264739155914176(廖雪峰)
简介:Commons Logging和Log4j是比较老牌的,随着时代的进步,我们越来越多的人开始用SLF4J和Logback了
- 首先slf4j已被springboot内部已经集成,无需动pom
- 启动文件上面加@slf4j
- application.yml增加配置,后面要被用到
#输出日志信息
logging:
level:
com.oneonline.teaching.admin: debug #debug(调试 ) < info(消息) < warn(警告) < error(错误) < fatal(严重错误)。
path: ${LOG_PATH:/Users/wt/work/java/mySpringboot}
- resources/增加文件logback-spring.xml,有加载顺序,命名需这样命名,可参考这个
- 见xml配置
<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">
<include resource="org/springframework/boot/logging/logback/defaults.xml"/>
<property resource="application.yml"/>
<!--定义-日志文件的存储地址 勿在 LogBack 的配置中使用相对路径-->
<springProperty name="LOG_HOME" scope="context" source="logging.path" defaultValue="/Users/wt/work/java/mySpringboot/log"/>
<!-- 控制台输出 -->
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
</encoder>
</appender>
<!-- 按照每天生成日志文件 -->
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!--日志文件输出的文件名-->
<FileNamePattern>${LOG_HOME}/SpringBoot-Slf4j_%d{yyyy-MM-dd}.log</FileNamePattern>
<!--日志文件保留天数-->
<MaxHistory>30</MaxHistory>
</rollingPolicy>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<!--格式化输出:%d表示日期,%thread表示线程名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
</encoder>
<!--日志文件最大的大小-->
<triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
<MaxFileSize>10MB</MaxFileSize>
</triggeringPolicy>
</appender>
<!-- 定义控制台输出 -->
<property name="CONSOLE_LOG_PATTERN" value="%boldMagenta([%d{yyyy-MM-dd HH:mm:ss.SSS}]) %cyan([%X{requestId}]) %cyan([${PID:- }]) %boldMagenta(%-5level) %red([%thread]) %blue(%logger{15}) %blue(%L) %magenta(:) %cyan(%msg%n)"/>
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<!-- 变量引入 -->
<pattern>${CONSOLE_LOG_PATTERN}</pattern>
<charset>UTF-8</charset>
<!--格式化输出:%d表示日期,%thread表示线程
名,%-5level:级别从左显示5个字符宽度%msg:日志消息,%n是换行符-->
<!-- <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>-->
</encoder>
</appender>
<!-- 日志输出级别 -->
<logger name="org.springframework" level="INFO"/>
<logger name="com.example.myspringboot" level="INFO"/>
<root level="INFO">
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE"/>
</root>
</configuration>
tip:日后会更新结合阿里云日志服务