版权声明:未经允许,请勿转载 https://blog.csdn.net/weixin_43723712/article/details/84204433
目前建议日志选择
slf4j+logback
日志门面:slf4j
日志实现:logback
slf4j如何实现日志门面?
如图所示,application通过slf4j API接口进行日志调用,slf4j 会调用相应实现类中的方法
项目如何实现统一日志记录?
日志适配图:依据该图进行Spring Boot日志框架的切换
Spring Boot 日志关系
Spring Boot默认使用了slf4j+logback组合进行日志管理,并且把其他的日志替换为了slf4j,进行统一的日志记录
Spring Boot 的日志的maven依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
<version>2.1.0.RELEASE</version>
<scope>compile</scope>
</dependency>
底层依赖关系
引入其他框架时,为了让Spring Boot能适配所有的框架且底层使用slf4j+logback,需要排除框架本身的日志依赖
Spring Boot日志默认配置
1.默认日志级别为info
2.修改默认配置
//修改默认的日志级别
logging.level.com.zkq.springboot.study=debug
//指定指定日志输出到文件中文件的名称(一般不使用)
logging.file=
//指定日志输出到文件中文件的地址
logging.path=
//指定控制台日志输出格式
logging.pattern.console=
//指定文件中日志输出格式
logging.pattern.file=
3.如果自定义名为logback-spring.xml,由Spring Boot进行日志配置解析,可以使用Spring Boot的高级功能–多环境配置
多环境配置语句:
扫描二维码关注公众号,回复:
5859033 查看本文章
<springProfile name="dev"></springProfile >
logback-spring.xml配置如下:
<?xml version="1.0" encoding="UTF-8" ?>
<configuration status="warn">
<property name="LOG_PATTERN"
value="%date{yyyy-MM-dd HH:mm:ss} |%-5level |%thread |%file:%line |%logger |%msg%n"/>
<!-- appender是configuration的子节点,是负责写日志的组件。 -->
<!-- 控制台打印日志配置 -->
<appender name="console_log" class="ch.qos.logback.core.ConsoleAppender">
<!--设置日志的输出格式-->
<encoder>
<pattern>${LOG_PATTERN}</pattern>
<charset>utf-8</charset>
</encoder>
</appender>
<springProfile name="!dev">
<!-- 写入文件 INFO 日志配置 -->
<!--级别排序为: TRACE < DEBUG < INFO < WARN < ERROR。-->
<appender name="file_info_log" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>INFO</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
<encoder>
<charset>UTF-8</charset>
<pattern>${LOG_PATTERN}</pattern>
</encoder>
<!-- TimeBasedRollingPolicy: 最常用的滚动策略,它根据时间来制定滚动策略,既负责滚动也负责出发滚动 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 活动文件的名字会根据fileNamePattern的值,每隔一段时间改变一次 -->
<!-- 文件名:log/demo.2017-12-05.0.log -->
<fileNamePattern>logs/info/info.%d.log</fileNamePattern>
<!-- 每产生一个日志文件,该日志文件的保存期限为30天 -->
<maxHistory>30</maxHistory>
</rollingPolicy>
</appender>
<!-- 写入文件 ERROR 日志配置 -->
<appender name="file_error_log" class="ch.qos.logback.core.rolling.RollingFileAppender">
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>ERROR</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
<encoder>
<charset>UTF-8</charset>
<pattern>${LOG_PATTERN}</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>logs/error/error.%d.log</fileNamePattern>
<maxHistory>30</maxHistory>
</rollingPolicy>
</appender>
</springProfile>
<!-- SQL相关日志输出-->
<logger name="org.apache.ibatis" level="INFO" additivity="false" />
<logger name="org.mybatis.spring" level="INFO" additivity="false" />
<logger name="org.hibernate" level="info" additivity="false"></logger>
<!--spring相关日志输出-->
<logger name="org.springframework.boot" level="info" additivity="false"></logger>
<logger name="org.springframework.beans" level="info" additivity="false"></logger>
<logger name="org.springframework.core" level="info" additivity="false"></logger>
<logger name="org.springframework.web" level="info" additivity="false"></logger>
<logger name="org.springframework.jmx" level="info" additivity="false"></logger>
<root level="DEBUG">
<!--测试,开发使用配置-->
<springProfile name="dev">
<appender-ref ref="console_log"/>
</springProfile>
<!--项目上线使用配置-->
<springProfile name="!dev">
<appender-ref ref="file_info_log"/>
<appender-ref ref="file_error_log"/>
</springProfile>
</root>
</configuration>