1.日誌框架html
市面上的日誌框架:java
JUL、JCL、Jboss-logging、logback、log4j、log4j二、slf4j...web
日誌門面(日誌的抽象層) | 日誌實現 |
JCL(Jakarta Commons Logging) spring SLF4j(Simple Logging Facade for Java) app jboss-logging框架 |
Log4j JUL(java.util.logging)spring-boot Log4j2spa Logback線程 |
左邊選一個門面(抽象層)、右邊來選一個實現;debug
日誌門面:SLF4j
日誌實現:Logback
SpringBoot:底層是Spring框架,Spring框架默認是用JCL;
SpringBoot選用SLF4j和logback
2.SLF4j使用
1.如何在系統中使用SLF4j
之後開發的時候,日誌記錄方法的調用,不用改來直接調用日誌的實現類,而是調用日誌抽象層裏面的方法;
給系統裏面導入slf4j的jar和logback的實現jar
1 import org.slf4j.Logger; 2 import org.slf4j.LoggerFactory; 3 4 public class HelloWorld { 5 public static void main(String[] args) { 6 Logger logger = LoggerFactory.getLogger(HelloWorld.class); 7 logger.info("Hello World"); 8 } 9 }
圖示:
每個日誌的實現框架都有本身的配置文件,使用slf4j之後,配置文件仍是作成日誌實現框架本身自己的配置文件;
2.遺留問題
a系統(slf4j+logback):Spring(commons-logging)、Hibernate(jboss-logging)、Mybatis...
統一日誌記錄,即便是別的框架和我一塊兒統一使用slf4j進行輸出
如何讓系統中全部的日誌都統一到slf4j:
1.將系統中其餘日誌框架先排除出去;
2.用中間包來替換原有的日誌框架;
3.咱們導入slf4j其餘的實現;
3.SpringBoot日誌關係
1 <dependency> 2 <groupId>org.springframework.boot</groupId> 3 <artifactId>spring-boot-starter</artifactId> 4 </dependency>
SpringBoot使用它來作日誌功能;
1 <dependency> 2 <groupId>org.springframework.boot</groupId> 3 <artifactId>spring-boot-starter-logging</artifactId> 4 </dependency>
底層依賴關係
總結:
1.SpringBoot底層也是使用slf4j+logback的方式進行日誌記錄
2.SpringBoot也把其餘的日誌都替換成了slf4j;
3.中間替換包
1 public abstract class LogFactory { 2 static String UNSUPPORTED_OPERATION_IN_JCL_OVER_SLF4J = "http://www.slf4j.org/codes.html#unsupported_operation_in_jcl_over_slf4j"; 3 static LogFactory logFactory = new SLF4JLogFactory();
4.若是咱們要引入其餘框架,必定要把這個框架的默認日誌依賴移除掉
Spring框架用的是conmmons-logging
1 <dependency> 2 <groupId>org.springframework</groupId> 3 <artifactId>spring-core</artifactId> 4 <exclusions> 5 <exclusion> 6 <groupId>commons-logging</groupId> 7 <artifactId>commons-logging</artifactId> 8 </exclusion> 9 </exclusions> 10 </dependency>
SpringBoot能自動適配全部的日誌,並且底層使用slf4j+logback的方式記錄日誌,引入其餘框架的時候,只須要把這個框架依賴的日誌框架排除掉
4.日誌使用
1.默認設置
SpringBoot默認幫咱們配置好了日誌;
1 //記錄器 2 Logger logger = LoggerFactory.getLogger(getClass()); 3 4 @Test 5 public void contextLoads() { 6 7 //日誌的級別 8 //由低到高 trace<debug<info<warn<error 9 //能夠調整日誌輸出的級別;日誌就只會在這個級別之後的高級別生效 10 logger.trace("這是trace日誌..."); 11 logger.debug("這是debug日誌..."); 12 //SpringBoot默認給咱們使用的是info級別的,沒有指定級別的就用SpringBoot默認規定的級別:root級別 13 logger.info("這是info日誌..."); 14 logger.warn("這是warn日誌..."); 15 logger.error("這是error日誌..."); 16 17 }
1 日誌輸出格式: 2 %d表示日期時間, 3 %thread表示線程名, 4 %-5level:級別從左顯示5個字符寬度 5 %logger{50} 表示logger名字最長50個字符,不然按照句點分割。 6 %msg:日誌消息, 7 %n是換行符 8 --> 9 %d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
SpringBoot修改日誌的默認配置
1 logging.level.com.young=trace 2 3 # 不指定路徑在當前項目下生成springBoot.log日誌 4 # 能夠指定完整的路徑 5 #logging.file=springBoot.log 6 # 在當前磁盤的根路徑下建立spring文件夾和裏面的log文件夾;使用spring.log做爲默認文件 7 logging.path=/spring/log 8 9 # 在控制檯輸出的日誌的格式 10 logging.pattern.console=%d{yyyy-MM-dd} [%thread] %-5level %logger{50} - %msg%n 11 # 指定文件中日誌輸出的格式 12 logging.pattern.file=%d{yyyy-MM-dd} === [%thread] === %-5level === %logger{50} ==== %msg%n
logging.file | logging.path | Example | Description |
(none) | (none) | 只在控制檯輸出 | |
指定文件名 | (none) | my.log | 輸出日誌到my.log文件 |
(none) | 指定目錄 | /var/log | 輸出到指定目錄的spring.log文件中 |
2.指定配置
給類路徑下放上每一個日誌框架本身的配置文件便可;SpringBoot就不使用他默認配置的了
Logging System | Customization |
Logback | logback-spring.xml、logback-spring.groovy、logback.xml or logback.groovy |
Log4j2 | log4j2-spring.xml or log4j2.xml |
JDK (Java Util Logging) | logging.properties |
logback.xml:直接就被日誌框架識別了;
logback-spring.xml:日誌框架就不直接加載日誌的配置項,由SpringBoot解析日誌配置,可使用SpringBoot的高級Profile功能
1 <springProfile name="staging"> 2 <!-- configuration to be enabled when the "staging" profile is active --> 3 能夠指定某段配置只在某個環境下生效 4 </springProfile>
不然
1 no applicable action for [springProfile]
1 <appender name="stdout" class="ch.qos.logback.core.ConsoleAppender"> 2 <!-- 3 日誌輸出格式: 4 %d表示日期時間, 5 %thread表示線程名, 6 %-5level:級別從左顯示5個字符寬度 7 %logger{50} 表示logger名字最長50個字符,不然按照句點分割。 8 %msg:日誌消息, 9 %n是換行符 10 --> 11 <layout class="ch.qos.logback.classic.PatternLayout"> 12 <springProfile name="dev"> 13 <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} ----> [%thread] ---> %-5level %logger{50} - %msg%n</pattern> 14 </springProfile> 15 <springProfile name="!dev"> 16 <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} ==== [%thread] ==== %-5level %logger{50} - %msg%n</pattern> 17 </springProfile> 18 </layout> 19 </appender>
5.切換日誌框架
能夠按照slf4j的日誌適配圖,進行相關的切換;
slf4j+log4j的方式;
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <artifactId>logback-classic</artifactId> <groupId>ch.qos.logback</groupId> </exclusion> <exclusion> <artifactId>log4j-over-slf4j</artifactId> <groupId>org.slf4j</groupId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> </dependency>
切換爲log4j2
1 <dependency> 2 <groupId>org.springframework.boot</groupId> 3 <artifactId>spring-boot-starter-web</artifactId> 4 <exclusions> 5 <exclusion> 6 <artifactId>spring-boot-starter-logging</artifactId> 7 <groupId>org.springframework.boot</groupId> 8 </exclusion> 9 </exclusions> 10 </dependency> 11 12 <dependency> 13 <groupId>org.springframework.boot</groupId> 14 <artifactId>spring-boot-starter-log4j2</artifactId> 15 </dependency>