SLF4J就粉末登场了。

1.简介

SLF4J支持{}作为占位符,而不必再进行字符串的拼接,效率有显著的提升。

2. 依赖

<dependency>    
   <groupId>ch.qos.logback</groupId>    
   <artifactId>logback-classic</artifactId>    
</dependency>  
 <dependency>                                      
    <groupId>org.slf4j</groupId>                  
    <artifactId>jcl-over-slf4j</artifactId>       
</dependency>

3. 配置logback

在  src\main\resources 路径下创建logback-spring.xml配置文件。

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
      
    <!--定义日志文件的存储地址 勿在 LogBack的配置中使用相对路径 -->  
    <property name="LOG_HOME" value="D:/tmp/log" />  
  
    <!-- 控制台输出 -->  
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">  
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">  
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{30} - %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}D:/logs/smsismp.log.%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{30} - %msg%n</pattern>  
        </encoder>  
        <!--日志文件最大的大小 -->  
        <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">  
            <MaxFileSize>10MB</MaxFileSize>  
        </triggeringPolicy>  
    </appender>  
       
    <!-- 日志输出级别 -->  
    <root level="INFO">  
        <appender-ref ref="STDOUT" /> 
        <appender-ref ref="FILE" />    
    </root>  
  
    <!-- 定义各个包的详细路径,继承root的值 -->  
    <logger name="com.hry.spring.log" level="INFO" />  
    <logger name="com.hry.spring" level="TRACE" />  
      
    <!-- 此值由 application.properties的spring.profiles.active=dev指定-->  
    <springProfile name="dev">   
        <property name="LOG_HOME" value="D:/tmp/log" />  
        <logger name="org.springboot.sample" level="DEBUG" />  
    </springProfile>  
  
    <springProfile name="pro">  
        <property name="LOG_HOME" value="D:/home" />  
        <logger name="org.springboot.sample2" level="INFO" />  
    </springProfile>  
      
</configuration>

encoder:定义输出格式
        %d{HH:mm:ss.SSS}——日志输出时间
        %thread——输出日志的进程名字,这在Web应用以及异步任务处理中很有用
        %-5level——日志级别,并且使用5个字符靠左对齐
        %logger{36}——日志输出者的名字
        %msg——日志消息

        %n——平台的换行符

application.properties指定本次启动的active的值是什么。

spring.profiles.active=dev

4. 测试

package com.example.demo;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

@RunWith(SpringRunner.class)
@SpringBootTest
public class DemoApplicationTests {

	@Test
	public void contextLoads() {
	}

	private static final Logger logger = LoggerFactory.getLogger(DemoApplicationTests.class);
	@Test
	public void test1(){
		logger.info("Current Time: {}", System.currentTimeMillis());
		logger.info("Current Time: " + System.currentTimeMillis());
		logger.info("Current Time: {}", System.currentTimeMillis());
		logger.trace("trace log");
		logger.warn("warn log");
		logger.debug("debug log");
		logger.info("info log");
		logger.error("error log");
	}
}