一、日志框架的选择

市面上常见的日志框架有很多,它们可以被分为两类:日志门面(日志抽象层)和日志实现,如下表:

通常情况下,日志由一个日志门面与一个日志实现组合搭建而成,Spring Boot 选用 SLF4J + Logback 的组合来搭建日志系统。

SLF4J 是目前市面上最流行的日志门面,使用 Slf4j 可以很灵活的使用占位符进行参数占位,简化代码,拥有更好的可读性。

Logback 是 Slf4j 的原生实现框架,它与 Log4j 出自一个人之手,但拥有比 log4j 更多的优点、特性和更做强的性能,现在基本都用来代替 log4j 成为主流。

二、日志的使用

在项目开发中,日志记录方法的调用,不应该来直接调用日志的实现类,而是调用日志抽象层里面的方法

现在用 SLF4J 来举例。使用 SLF4J 记录日志时,我们需要在应用中导入 SLF4J 及日志实现,并在记录日志时调用 SLF4J 的方法,例如:

LoggerTest.java:

package com.xj.main;import org.junit.jupiter.api.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.test.context.SpringBootTest;
/*** @Author : xjfu* @Date : 2022/7/15 9:17* @Description :*/@SpringBootTest
public class LoggerTest {Logger logger = LoggerFactory.getLogger(getClass());@Testpublic void logTest(){//调用的是slf4j的trace、debug、info、warn和error方法,而不是logback的方法logger.trace("trace 级别日志");logger.debug("debug 级别日志");logger.info("info 级别日志");logger.warn("warn 级别日志");logger.error("error 级别日志");}
}

三、统一日志框架

通常一个完整的应用下会依赖于多种不同的框架,而且每一种框架记录日志时使用的日志框架也不尽相同,例如,Spring Boot(slf4j+logback),Spring(commons-logging)、Hibernate(jboss-logging)等等。那么如何统一日志框架的使用呢?

对此,SLF4J 官方也给出了相应的解决方案,如下图。

从上图中可以看出,统一日志框架一共需要以下 3 步 :

  1. 排除应用中的原来的日志框架;
  2. 引入替换包替换被排除的日志框架;
  3. 导入 SLF4J 实现。

SLF4J 官方给出的统一日志框架的方案是“狸猫换太子”,即使用一个替换包来替换原来的日志框架,例如 log4j-over-slf4j 替换 Log4j(Commons Logging API)、jul-to-slf4j.jar 替换 JUL(java.util.logging API)等等。
        替换包内包含被替换的日志框架中的所有类,这样就可以保证应用不会报错,但替换包内部实际使用的是 SLF4J API,以达到统一日主框架的目的。

四、Spring Boot统一日志框架

我们在使用 Spring Boot 时,同样可能用到其他的框架,例如 Mybatis、Spring MVC、 Hibernate 等等,这些框架的底层都有自己的日志框架,此时我们也需要对日志框架进行统一。
        我们知道,统一日志框架的使用一共分为 3 步,Soring Boot 作为一款优秀的开箱即用的框架,已经为用户完成了其中 2 步:引入替换包和导入 SLF4J 实现。

Spring Boot 的核心启动器 spring-boot-starter 引入了 spring-boot-starter-logging,使用 IDEA 查看其依赖关系,如下图:

从图上图可知,spring-boot-starter-logging 的 Maven 依赖不但引入了 logback-classic (包含了日志框架 SLF4J 的实现),还引入了 log4j-to-slf4j(log4j 的替换包),jul-to-slf4j (JUL 的替换包),即 Spring Boot 已经为我们完成了统一日志框架的 3 个步骤中的 2 步。
        SpringBoot 底层使用 slf4j+logback 的方式记录日志,当我们引入了依赖了其他日志框架的第三方框架(例如 Hibernate)时,只需要把这个框架所依赖的日志框架排除,即可实现日志框架的统一,示例代码如下:

<dependency><groupId>org.apache.activemq</groupId><artifactId>activemq-console</artifactId><version>${activemq.version}</version><exclusions><exclusion><groupId>commons-logging</groupId><artifactId>commons-logging</artifactId></exclusion></exclusions>
</dependency>

五、日志信息解析

1.Spring Boot默认日志输出级别和日志输出信息分析

可以看出Spring Boot的日志默认输出级别为info。

默认的日志输出如下

2022-07-15 09:28:28.792  INFO 6896 --- [           main] com.xj.main.LoggerTest                   : Started LoggerTest in 4.42 seconds (JVM running for 7.307)2022-07-15 09:28:29.117  INFO 6896 --- [           main] com.xj.main.LoggerTest                   : info 级别日志
2022-07-15 09:28:29.117  WARN 6896 --- [           main] com.xj.main.LoggerTest                   : warn 级别日志
2022-07-15 09:28:29.118 ERROR 6896 --- [           main] com.xj.main.LoggerTest                   : error 级别日志

输出内容元素具体如下

  • 时间日期 — 精确到毫秒
  • 日志级别 — ERROR, WARN, INFO, DEBUG or TRACE
  • 进程ID
  • 分隔符 — --- 标识实际日志的开始
  • 线程名 — 方括号括起来(可能会截断控制台输出)
  • Logger名 — 通常使用源代码的类名
  • 日志内容

2.日志级别

以上日志级别依次由低到高,即1<2<3<4<5。

当一条日志信息的级别大于或等于配置文件的级别时,就对这条日志进行记录,即配置文件的日志级别为info时,那么error、warn、info级别的日志都会被记录。

3.日志格式拼装

序号 输出格式 说明
1 %d{yyyy-MM-dd HH:mm:ss, SSS}  日志生产时间,输出到毫秒的时间
2 %-5level  输出日志级别,-5 表示左对齐并且固定输出 5 个字符,如果不足在右边补 0
3 %logger 或 %c  logger 的名称
4 %thread  或 %t 输出当前线程名称
5 %p 日志输出格式
6 %message 或 %msg 或 %m 日志内容,即 logger.info("message")
7 %n 换行符
8 %class 或 %C 输出 Java 类名
9 %file 或 %F 输出文件名
10 %L 输出错误行号
11 %method 或 %M 输出方法名
12 %l  输出语句所在的行数, 包括类名、方法名、文件名、行数
13 hostName 本地机器名
14 hostAddress 本地 ip 地址

六、日志信息控制

1.配置文件application.properties/yml控制日志信息

我们可以根据自身的需求,通过全局配置文件(application.properties/yml)修改 Spring Boot 日志级别和显示格式等默认配置。在 application.properties/yml 中,修改 Spring Boot 日志的默认配置,代码如下:

#日志级别 com.xj包下面日志级别为trace
logging.level.com.xj=trace
#使用相对路径定义日志位置及文件名(项目根路径下myLog/logs/mySpring.log)
logging.file.name=myLog/logs/mySpring.log
#使用相对路径的方式设置日志输出的位置(项目根目录目录\myLog\logs\spring.log)
logging.file.path=my-log/myLog
#绝对路径方式将日志文件输出到 【项目所在磁盘根目录\springboot\logging\my\spring.log】
logging.file.path=/spring-boot/logging
#控制台日志输出格式
logging.pattern.console=%d{yyyy-MM-dd hh:mm:ss} [%thread] %-5level %logger{50} - %msg%n
#日志文件输出格式
logging.pattern.file=%d{yyyy-MM-dd} === [%thread] === %-5level === %logger{50} === - %msg%n

(1)项目举例

1)项目框架

2)代码实现

MainApplicaion.java:

package com.xj.main;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ComponentScan;/*** @Author : xjfu* @Date : 2022/6/8 8:38* @Description :Spring Boot 启动类*/
@ComponentScan("com.xj")
@SpringBootApplication
public class MainApplication {public static void main(String[] args) {SpringApplication.run(MainApplication.class, args);}
}

LoggerTest.java:

package com.xj.main;import org.junit.jupiter.api.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.test.context.SpringBootTest;
/*** @Author : xjfu* @Date : 2022/7/15 9:17* @Description :*/@SpringBootTest
public class LoggerTest {Logger logger = LoggerFactory.getLogger(getClass());@Testpublic void logTest(){//调用的是slf4j的trace、debug、info、warn和error方法,而不是logback的方法logger.trace("trace 级别日志");logger.debug("debug 级别日志");logger.info("info 级别日志");logger.warn("warn 级别日志");logger.error("error 级别日志");}
}

application.yml:

#端口号配置
server:port: 8088servlet:context-path: /xj
#日志配置
logging:level: #日志级别控制com:xj: debug #com.xj包下面的日志基本都为debug级file:path: myLog/logs #日志文件路径为myLog/logspattern:console: "%d{yyyy-MM-dd hh:mm:ss} [%thread] %-5level %logger{50} - %msg%n" #控制台日志输出格式file: "%d{yyyy-MM-dd} === [%thread] === %-5level === %logger{50} === - %msg%n" #日志文件输出格式

pom.xml:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.xj.study</groupId><artifactId>spring-boot-study-project</artifactId><version>1.0-SNAPSHOT</version><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.4.5</version><relativePath/></parent><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-configuration-processor</artifactId><optional>true</optional></dependency></dependencies><!--build标签描述了如何来编译及打包项目,而具体的编译和打包工作是通过build中配置的 plugin 来完成--><build><plugins><!--使用SpringBoot的打包插件--><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><executions><execution><goals><goal>repackage</goal></goals></execution></executions></plugin></plugins></build>
</project>

3)运行结果

1》使用默认日志文件名spring.log

2》自定义日志文件名mySpring.log

修改application.yml:

#端口号配置
server:port: 8088servlet:context-path: /xj
#日志配置
logging:level: #日志级别控制com:xj: debug #com.xj包下面的日志基本都为debug级file:name: myLog/logs/mySpring.log #使用相对路径定义日志位置及文件名(项目根路径下myLog/logs/mySpring.logpattern:console: "%d{yyyy-MM-dd hh:mm:ss} [%thread] %-5level %logger{50} - %msg%n" #控制台日志输出格式file: "%d{yyyy-MM-dd} === [%thread] === %-5level === %logger{50} === - %msg%n" #日志文件输出格式

2.自定义日志配置文件控制日志信息

在 Spring Boot 的配置文件 application.porperties/yml 中,可以对日志的一些默认配置进行修改,但这种方式只能修改个别的日志配置,想要修改更多的配置或者使用更高级的功能,则需要通过日志实现框架自己的配置文件进行配置。
        Spring 官方提供了各个日志实现框架所需的配置文件,用户只要将指定的配置文件放置到项目的类路径下即可。

日志框架 配置文件
Logback logback-spring.xml、logback-spring.groovy、logback.xml、logback.groovy
Log4j2 log4j2-spring.xml、log4j2.xml
JUL (Java Util Logging) logging.properties

从上表可以看出,日志框架的配置文件基本上被分为 2 类:

  • 普通日志配置文件,即不带 srping 标识的配置文件,例如 logback.xml;
  • 带有 spring 标识的日志配置文件,例如 logback-spring.xml。

这两种日志配置文件在使用时大不相同,下面我们就对它们分别进行介绍。

(1)普通日志配置文件

我们将 logback.xml、log4j2.xml 等不带 spring 标识的普通日志配置文件,放在项目的类路径下后,这些配置文件会跳过 Spring Boot,直接被日志框架加载。通过这些配置文件,我们就可以达到自定义日志配置的目的。

1)项目举例

1》项目框架

2》代码实现

MainApplication.java:

package com.xj.main;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.ComponentScan;/*** @Author : xjfu* @Date : 2022/6/8 8:38* @Description :Spring Boot 启动类*/
@ComponentScan("com.xj")
@SpringBootApplication
public class MainApplication {public static void main(String[] args) {SpringApplication.run(MainApplication.class, args);}
}

LoggerTest.java:

package com.xj.main;import org.junit.jupiter.api.Test;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.test.context.SpringBootTest;
/*** @Author : xjfu* @Date : 2022/7/15 9:17* @Description :*/@SpringBootTest
public class LoggerTest {Logger logger = LoggerFactory.getLogger(getClass());@Testpublic void logTest(){//调用的是slf4j的trace、debug、info、warn和error方法,而不是logback的方法logger.trace("trace 级别日志");logger.debug("debug 级别日志");logger.info("info 级别日志");logger.warn("warn 级别日志");logger.error("error 级别日志");}
}

application.yml:

#端口号配置
server:port: 8088servlet:context-path: /xjlogging:config: classpath:logback.xml #指定使用哪个日志配置文件

logback.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!--
scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true。
scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒当scan为true时,此属性生效。默认的时间间隔为1分钟。
debug:当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。
-->
<configuration scan="false" scanPeriod="60 seconds" debug="false"><!-- 定义日志的根目录 --><property name="LOG_HOME" value="app/log"/><!-- 定义日志文件名称 --><property name="appName" value="bianchengbang-spring-boot-logging"></property><!-- ch.qos.logback.core.ConsoleAppender 表示控制台输出 --><appender name="stdout" class="ch.qos.logback.core.ConsoleAppender"><!--日志输出格式:%d:表示日期时间,%thread:表示线程名,%-5level:级别从左显示5个字符宽度%logger{50}:表示logger名字最长50个字符,否则按照句点分割。%msg:日志消息,%n:是换行符--><layout class="ch.qos.logback.classic.PatternLayout"><pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread]**************** %-5level %logger{50} - %msg%n</pattern></layout></appender><!-- 滚动记录文件,先将日志记录到指定文件,当符合某个条件时,将日志记录到其他文件 --><appender name="appLogAppender" class="ch.qos.logback.core.rolling.RollingFileAppender"><!-- 指定日志文件的名称 --><file>${LOG_HOME}/${appName}.log</file><!--当发生滚动时,决定 RollingFileAppender 的行为,涉及文件移动和重命名TimeBasedRollingPolicy: 最常用的滚动策略,它根据时间来制定滚动策略,既负责滚动也负责出发滚动。--><rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"><!--滚动时产生的文件的存放位置及文件名称%d{yyyy-MM-dd}:按天进行日志滚动%i:当文件大小超过maxFileSize时,按照i进行文件滚动--><fileNamePattern>${LOG_HOME}/${appName}-%d{yyyy-MM-dd}-%i.log</fileNamePattern><!--可选节点,控制保留的归档文件的最大数量,超出数量就删除旧文件。假设设置每天滚动,且maxHistory是365,则只保存最近365天的文件,删除之前的旧文件。注意,删除旧文件是指那些为了归档而创建的目录也会被删除。--><MaxHistory>365</MaxHistory><!--当日志文件超过maxFileSize指定的大小是,根据上面提到的%i进行日志文件滚动 注意此处配置SizeBasedTriggeringPolicy是无法实现按文件大小进行滚动的,必须配置timeBasedFileNamingAndTriggeringPolicy--><timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"><maxFileSize>100MB</maxFileSize></timeBasedFileNamingAndTriggeringPolicy></rollingPolicy><!-- 日志输出格式: --><layout class="ch.qos.logback.classic.PatternLayout"><pattern>%d{yyyy-MM-dd HH:mm:ss} [ %thread ] ------------------ [ %-5level ] [ %logger{50} : %line ] - %msg%n</pattern></layout></appender><!--logger可选节点,用来具体指明包的日志输出级别,它将会覆盖root的输出级别name:表示匹配的logger类型前缀,也就是包的前半部分level:要记录的日志级别,包括 TRACE < DEBUG < INFO < WARN < ERRORadditivity:作用在于children-logger是否使用 rootLogger配置的appender进行输出,false:表示只用当前logger的appender-reftrue:表示当前logger的appender-ref和rootLogger的appender-ref都有效--><!-- hibernate logger --><logger name="net.biancheng.www" level="debug"/><!-- Spring framework logger --><logger name="org.springframework" level="debug" additivity="false"></logger><!--root与logger是父子关系,没有特别定义则默认为root,任何一个类只会和一个logger对应,要么是定义的logger,要么是root,判断的关键在于找到这个logger,然后判断这个logger的appender和level。--><root level="info"><appender-ref ref="stdout"/><appender-ref ref="appLogAppender"/></root>
</configuration>

pom.xml:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.xj.study</groupId><artifactId>spring-boot-study-project</artifactId><version>1.0-SNAPSHOT</version><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.4.5</version><relativePath/></parent><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-configuration-processor</artifactId><optional>true</optional></dependency></dependencies><!--build标签描述了如何来编译及打包项目,而具体的编译和打包工作是通过build中配置的 plugin 来完成--><build><plugins><!--使用SpringBoot的打包插件--><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><executions><execution><goals><goal>repackage</goal></goals></execution></executions></plugin></plugins></build>
</project>

3》运行结果

bianchengbang-spring-boot-logging.log:

2022-07-20 19:33:04 [ main ] ------------------ [ INFO  ] [ com.xj.main.LoggerTest : 55 ] - Starting LoggerTest using Java 1.8.0_161 on PC-2019071046 with PID 12780 (started by xjfu in D:\ideaWorkplace\SpringBootStudyProject)
2022-07-20 19:33:04 [ main ] ------------------ [ INFO  ] [ com.xj.main.LoggerTest : 675 ] - No active profile set, falling back to default profiles: default
2022-07-20 19:33:06 [ main ] ------------------ [ INFO  ] [ com.xj.main.LoggerTest : 61 ] - Started LoggerTest in 2.062 seconds (JVM running for 3.319)
2022-07-20 19:33:06 [ main ] ------------------ [ INFO  ] [ com.xj.main.LoggerTest : 23 ] - info 级别日志
2022-07-20 19:33:06 [ main ] ------------------ [ WARN  ] [ com.xj.main.LoggerTest : 24 ] - warn 级别日志
2022-07-20 19:33:06 [ main ] ------------------ [ ERROR ] [ com.xj.main.LoggerTest : 25 ] - error 级别日志

(2)带有spring标识的日志配置文件

Spring Boot 推荐用户使用 logback-spring.xml、log4j2-spring.xml 等这种带有 spring 标识的配置文件。这种配置文件被放在项目类路径后,不会直接被日志框架加载,而是由 Spring Boot 对它们进行解析,这样就可以使用 Spring Boot 的高级功能 Profile,实现在不同的环境中使用不同的日志配置。

1)项目举例

首先将上面项目用到的 logback.xml 文件名修改为 logback-spring.xml,并将配置文件中日志输出格式的配置修改为使用 Profile 功能的配置。

配置内容修改前,日志输出格式配置如下:

    <!-- ch.qos.logback.core.ConsoleAppender 表示控制台输出 --><appender name="stdout" class="ch.qos.logback.core.ConsoleAppender"><layout class="ch.qos.logback.classic.PatternLayout"><pattern>%d{yyyy-MM-dd HH:mm:ss} [%thread]**************** %-5level %logger{50} - %msg%n</pattern></layout></appender>

修改 logback-spring.xml 的配置内容,通过 Profile 功能实现在不同的环境中使用不同的日志输出格式,配置如下:

    <!-- ch.qos.logback.core.ConsoleAppender 表示控制台输出 --><appender name="stdout" class="ch.qos.logback.core.ConsoleAppender"><layout class="ch.qos.logback.classic.PatternLayout"><!--开发环境 日志输出格式--><springProfile name="dev"><pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} ----> [%thread] ---> %-5level %logger{50} - %msg%n</pattern></springProfile><!--非开发环境 日志输出格式--><springProfile name="!dev"><pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} ==== [%thread] ==== %-5level %logger{50} - %msg%n</pattern></springProfile></layout></appender>

1》项目框架

2》代码实现

MainApplication.java:

(同上)

LoggerTest.java:

(同上)

application.yml:

#默认配置
server:port: 8080#切换配置
spring:profiles:active: dev #指定使用哪个profile---
#开发环境
server:port: 8081spring:config:activate:on-profile: dev
---
#测试环境
server:port: 8082spring:config:activate:on-profile: test
---
#生产环境
server:port: 8083spring:config:activate:on-profile: prodlogging:config: classpath:logback-spring.xml #指定使用哪个日志配置文件

logback-spring.xml:

<?xml version="1.0" encoding="UTF-8"?>
<!--
scan:当此属性设置为true时,配置文件如果发生改变,将会被重新加载,默认值为true。
scanPeriod:设置监测配置文件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒当scan为true时,此属性生效。默认的时间间隔为1分钟。
debug:当此属性设置为true时,将打印出logback内部日志信息,实时查看logback运行状态。默认值为false。
-->
<configuration scan="false" scanPeriod="60 seconds" debug="false"><!-- 定义日志的根目录 --><property name="LOG_HOME" value="app/log"/><!-- 定义日志文件名称 --><property name="appName" value="bianchengbang-spring-boot-logging"></property><!-- ch.qos.logback.core.ConsoleAppender 表示控制台输出 --><appender name="stdout" class="ch.qos.logback.core.ConsoleAppender"><layout class="ch.qos.logback.classic.PatternLayout"><!--开发环境 日志输出格式--><springProfile name="dev"><pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} ----> [%thread] ---> %-5level %logger{50} - %msg%n</pattern></springProfile><!--非开发环境 日志输出格式--><springProfile name="!dev"><pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} ==== [%thread] ==== %-5level %logger{50} - %msg%n</pattern></springProfile></layout></appender><!-- 滚动记录文件,先将日志记录到指定文件,当符合某个条件时,将日志记录到其他文件 --><appender name="appLogAppender" class="ch.qos.logback.core.rolling.RollingFileAppender"><!-- 指定日志文件的名称 --><file>${LOG_HOME}/${appName}.log</file><!--当发生滚动时,决定 RollingFileAppender 的行为,涉及文件移动和重命名TimeBasedRollingPolicy: 最常用的滚动策略,它根据时间来制定滚动策略,既负责滚动也负责出发滚动。--><rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"><!--滚动时产生的文件的存放位置及文件名称%d{yyyy-MM-dd}:按天进行日志滚动%i:当文件大小超过maxFileSize时,按照i进行文件滚动--><fileNamePattern>${LOG_HOME}/${appName}-%d{yyyy-MM-dd}-%i.log</fileNamePattern><!--可选节点,控制保留的归档文件的最大数量,超出数量就删除旧文件。假设设置每天滚动,且maxHistory是365,则只保存最近365天的文件,删除之前的旧文件。注意,删除旧文件是指那些为了归档而创建的目录也会被删除。--><MaxHistory>365</MaxHistory><!--当日志文件超过maxFileSize指定的大小是,根据上面提到的%i进行日志文件滚动 注意此处配置SizeBasedTriggeringPolicy是无法实现按文件大小进行滚动的,必须配置timeBasedFileNamingAndTriggeringPolicy--><timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"><maxFileSize>100MB</maxFileSize></timeBasedFileNamingAndTriggeringPolicy></rollingPolicy><!-- 日志输出格式: --><layout class="ch.qos.logback.classic.PatternLayout"><pattern>%d{yyyy-MM-dd HH:mm:ss} [ %thread ] ------------------ [ %-5level ] [ %logger{50} : %line ] - %msg%n</pattern></layout></appender><!--logger可选节点,用来具体指明包的日志输出级别,它将会覆盖root的输出级别name:表示匹配的logger类型前缀,也就是包的前半部分level:要记录的日志级别,包括 TRACE < DEBUG < INFO < WARN < ERRORadditivity:作用在于children-logger是否使用 rootLogger配置的appender进行输出,false:表示只用当前logger的appender-reftrue:表示当前logger的appender-ref和rootLogger的appender-ref都有效--><!-- hibernate logger --><logger name="net.biancheng.www" level="debug"/><!-- Spring framework logger --><logger name="org.springframework" level="debug" additivity="false"></logger><!--root与logger是父子关系,没有特别定义则默认为root,任何一个类只会和一个logger对应,要么是定义的logger,要么是root,判断的关键在于找到这个logger,然后判断这个logger的appender和level。--><root level="info"><appender-ref ref="stdout"/><appender-ref ref="appLogAppender"/></root>
</configuration>

pom.xml:

(同上)

3》运行结果

七、参考

1.Spring Boot统一日志框架

2.Spring Boot日志配置及输出

3.SpringBoot | 第四章:日志配置 | oKong | 趔趄的猿

4.logback.xml常用配置详解_spring_root的博客-CSDN博客_logback.xml

Spring Boot 日志(八)相关推荐

  1. ELK 处理 Spring Boot 日志,妙!

    以下文章来源方志朋的博客,回复"666"获面试宝典 在排查线上异常的过程中,查询日志总是必不可缺的一部分.现今大多采用的微服务架构,日志被分散在不同的机器上,使得日志的查询变得异常 ...

  2. ELK 处理 Spring Boot 日志,有点强悍!

    在排查线上异常的过程中,查询日志总是必不可缺的一部分.现今大多采用的微服务架构,日志被分散在不同的机器上,使得日志的查询变得异常困难.工欲善其事,必先利其器.如果此时有一个统一的实时日志分析平台,那可 ...

  3. 54. spring boot日志升级篇—logback【从零开始学Spring Boot】

    在<44. Spring Boot日志记录SLF4J>章节中有关相关的介绍,这里我们在深入的了解下logback框架. 为什么要使用logback ? --在开发中不建议使用System. ...

  4. 让你的spring-boot应用日志随心所欲--spring boot日志深入分析

    1.spring boot日志概述 spring boot使用Commons Logging作为内部的日志系统,并且给Java Util Logging,Log4J2以及Logback都提供了默认的配 ...

  5. Spring Boot日志集成

    Spring Boot日志框架 Spring Boot支持Java Util Logging,Log4j2,Lockback作为日志框架,如果你使用starters启动器,Spring Boot将使用 ...

  6. Spring Boot 日志管理

    在代码有问题的时候,很多人应该都是通过 debug 的方式去排查,往往忽略了日志的重要性. 好的日志管理可以快速定位问题出现的位置,也可以提高代码的阅读性.这篇博文主要介绍一下 Spring Boot ...

  7. springboot日志写入mysql_44. Spring Boot日志记录SLF4J【从零开始学Spring Boot】

    学院中有Spring Boot相关的课程!点击「阅读原文」进行查看! SpringSecurity5.0视频:http://t.cn/A6ZadMBe Sharding-JDBC分库分表实战: 在开发 ...

  8. Spring Boot 日志配置 ——logback

    一.logback默认的日志配置 Spring Boot 默认使用的日志框架是logback,如果我们没有自定义配置的话,logback将会使用他为默认的日志配置文件: classpath:logba ...

  9. Spring boot日志使用

    日志使用 Spring boot默认,配置好了日志 @RunWith(SpringRunner.class) @SpringBootTest public class SpringBoot03Logg ...

最新文章

  1. Adaboost通俗易懂入门教程
  2. H3C LMI协议标准
  3. Java实现1到n的倒数的累加和
  4. java在td中怎么用if_不在Java中使用if语句
  5. 【图文教程】Ubuntu software解决下载速度过慢
  6. java有没有回调函数_Java中的回调函数 - wangjianme的个人空间 - OSCHINA - 中文开源技术交流社区...
  7. java阻塞超时_JAVA防线程阻塞(超时控制)
  8. CentOS 7升级gcc 8.3.1 7.x.x 4.9.4版本
  9. Spring : @EnableConfigurationProperties注解
  10. 【4】求最大奇数公约数
  11. 快速实现python c扩展模块
  12. 创建一个地震Viewer
  13. 数控机床属于计算机应用领域,数控技术都应用到这些领域了!你还不知道!
  14. 关于只针对ie7浏览器的css问题
  15. paip.php 5.0 5.3 5.4 5.5 -6.0的新特性总结与比较
  16. 分享一个AUTO uninstaller|AUTOCAD 安装失败解决方案
  17. 计算机xp画板在哪找,xp系统画图工具在哪里|xp画图工具有什么功能
  18. Day 11 Contractions and Present Perfect
  19. CSS兼容性技巧整理从IE6-IE9 火狐谷歌浏览器兼容
  20. Funfile免费下载教程,还支持迅雷哦!!!

热门文章

  1. 简单使用示波器485通讯抓波形
  2. java数组越界异常并捕获_(Java)数组越界异常
  3. python定义多项式除法_多项式长除法
  4. Android系统与数字电视之我见
  5. HMM/GMM识别之三音素训练——决策树
  6. 如何正确曝光。关键:快门、光圈、ISO - [摄影基础]
  7. 计算机 服务未能登陆,w7电脑开机提示Group Policy Client服务未能登陆的修复方法...
  8. 在iPad上看PDF信息内容,哪个软件实用?
  9. 如何申请苹果的邓白氏编码(2020年)
  10. 2022年安全员-A证特种作业证考试题库及在线模拟考试