Spring2.x过后⾃带⽇志⼯具就是Slf4j
使⽤ Spring Initializr 新建 Springboot 2.3.0.RELEASE 的项⽬
POM内容如下
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="/POM/4.0.0" xmlns:xsi="/2001/XMLSchema-instance"
xsi:schemaLocation="/POM/4.0.0 /xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.0.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>net.add1s</groupId>
<artifactId>slf4j-logback</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>slf4j-logback</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
资源⽂件夹resources下新建l⽂档
<?xml version="1.0" encoding="UTF-8"?>
<!--
scan: 当此属性设置为true时,配置⽂件如果发⽣改变,将会被重新加载,默认值为true。
scanPeriod: 设置监测配置⽂件是否有修改的时间间隔,如果没有给出时间单位,默认单位是毫秒。当scan为true时,此属性⽣效。默认的时间间隔为1分钟。
debug: 当此属性设置为true时,将打印出logback内部⽇志信息,实时查看logback运⾏状态。默认值为false。
configuration ⼦节点为 appender、logger、root
-->
<configuration scan="true" scanPeriod="60 seconds" debug="false">
<!--⽤于区分不同应⽤程序的记录-->
<contextName>test-logback</contextName>
<!--⽇志⽂件所在⽬录,如果是tomcat,如下写法⽇志⽂件会在则为${TOMCAT_HOME}/bin/logs/⽬录下-->
<!-- <property name="LOG_HOME_WINDOWS" value="logs"/>-->
<property name="LOG_HOME_WINDOWS" value="D:/code_resource/workspace_all/idea/slf4j-logback/src/main/resources/logs"/>
<property name="LOG_HOME_LINUX" value="./logs"/>
<!-- 彩⾊⽇志 -->
<!-- 彩⾊⽇志依赖的渲染类 -->
<conversionRule conversionWord="clr" converterClass="org.springframework.boot.logging.logback.ColorConverter" />
<conversionRule conversionWord="wex" converterClass="org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter" />
<conversionRule conversionWord="wEx" converterClass="org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter" />
<!-- 彩⾊⽇志格式 [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n -->
<property name="CONSOLE_LOG_PATTERN" value="${CONSOLE_LOG_PATTERN:-%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr(---){faint} %clr([%15 <!--控制台-->
<appender name="stdout" class="ch.ConsoleAppender">
<encoder>
<!--格式化输出:%d表⽰⽇期,%thread表⽰线程名,%-5level:级别从左显⽰5个字符宽度 %logger输出⽇志的logger名 %msg:⽇志消息,%n是换⾏符 -->
<!-- <pattern>[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%thread] %-5level %logger{36} : %msg%n</pattern>-->
<pattern>${CONSOLE_LOG_PATTERN}</pattern><!--彩打⽇志-->
<!--解决乱码问题-->
<charset>UTF-8</charset>
</encoder>
</appender>
<!--滚动⽂件-->
<appender name="infoFile" class="ch.olling.RollingFileAppender">
<!-- ThresholdFilter:临界值过滤器,过滤掉 TRACE 和 DEBUG 级别的⽇志 -->
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>INFO</level>
</filter>
<rollingPolicy class="ch.olling.TimeBasedRollingPolicy">
<fileNamePattern>${LOG_HOME_WINDOWS}/info/info.%d{yyyy-MM-dd}.log</fileNamePattern>
<!-- <maxFileSize>100MB</maxFileSize><!&ndash;单个⽇志⽂件最⼤100M,到了这个值,就会再创建⼀个⽇志⽂件,⽇志⽂件的名字最后+1–>--> <maxHistory>30</maxHistory><!--保存最近30天的⽇志-->
<totalSizeCap>20GB</totalSizeCap><!--所有的⽇志⽂件最⼤20G,超过就会删除旧的⽇志-->
</rollingPolicy>
<encoder>
<charset>UTF-8</charset>
<pattern>[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%thread] %-5level %logger{36} : %msg%n</pattern>
</encoder>
</appender>
<!--滚动⽂件-->
<appender name="errorFile" class="ch.olling.RollingFileAppender">
<!-- ThresholdFilter:临界值过滤器,过滤掉 TRACE 和 DEBUG 级别的⽇志 -->
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>error</level>
</filter>
<rollingPolicy class="ch.olling.TimeBasedRollingPolicy">
<fileNamePattern>${LOG_HOME_WINDOWS}/error/error.%d{yyyy-MM-dd}.log</fileNamePattern>
<!-- <maxFileSize>100MB</maxFileSize><!&ndash;单个⽇志⽂件最⼤100M,到了这个值,就会再创建⼀个⽇志⽂件,⽇志⽂件的名字最后+1–>--> <maxHistory>30</maxHistory><!--保存最近30天的⽇志-->
<totalSizeCap>20GB</totalSizeCap><!--所有的⽇志⽂件最⼤20G,超过就会删除旧的⽇志-->
</rollingPolicy>
<encoder>
<charset>UTF-8</charset>
<pattern>[%d{yyyy-MM-dd HH:mm:ss.SSS}] [%thread] %-5level %logger{36} : %msg%n</pattern>
</encoder>
</appender>
<!--这⾥如果是info,spring、mybatis等框架则不会输出:TRACE < DEBUG < INFO < WARN < ERROR-->
<!--root是所有logger的初始级,均继承root,如果某⼀个⾃定义的logger没有指定level,就会寻⽗logger看有没有指定级别,直到到root。-->
<!-- <root level="debug">-->
<!-- <appender-ref ref="stdout"/>-->
<!--<!– <appender-ref ref="infoFile"/>–>-->
<!--<!– <appender-ref ref="errorFile"/>–>-->
<!--<!– <appender-ref ref="logstash"/>–>-->
<!-- </root>-->
<!--为某个包单独配置logger
⽐如定时任务,写代码的包名为:net.add1s.slf4j-logback
步骤如下:
1、定义⼀个appender,取名为task(随意,只要下⾯logger引⽤就⾏了)
appender的配置按照需要即可
2、定义⼀个logger:
<logger name="net.add1s.slf4j-logback" level="DEBUG" additivity="false">
<appender-ref ref="task" />
</logger>
注意:additivity必须设置为false,这样只会交给task这个appender,否则其他appender也会打印net.add1s.slf4j-logback⾥的log信息。
3、这样,在net.add1s.slf4j-logback的logger就会是上⾯定义的logger了。
idea debugprivate static Logger logger = Logger(Class1.class);
-->
<!--配置多环境⽇志输出可以在application.properties中配置选择哪个profiles : spring.profiles.active=dev-->
<!--开发环境:打印控制台-->
<springProfile name="dev">
<root level="debug">
<appender-ref ref="stdout" />
<appender-ref ref="infoFile" />
<appender-ref ref="errorFile" />
</root>
</springProfile>
<!--⽣产环境:输出到⽂件-->
<springProfile name="prd">
<root level="info">
<appender-ref ref="infoFile" />
<appender-ref ref="errorFile" />
</root>
</springProfile>
</configuration>
spring:
application:
name: slf4j-logback
profiles:
active: dev
-
--
# 开发环境配置
spring:
profiles: dev
server:
port: 1000
---
# 测试环境配置
spring:
profiles: test
server:
port: 1001
---
# ⽣产环境配置
spring:
profiles: prd
server:
port: 1002
参考
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论