(三)SpringBoot與日誌

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>
相關文章
相關標籤/搜索