亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

關(guān)于Springboot的日志配置

 更新時間:2023年05月18日 11:40:42   作者:不放糖的苦咖啡  
Spring Boot默認使用LogBack日志系統(tǒng),如果不需要更改為其他日志系統(tǒng)如Log4j2等,則無需多余的配置,LogBack默認將日志打印到控制臺上,需要的朋友可以參考下

日志是非常重要的,雖然他不會以需求功能提來,但也不會體現(xiàn)在產(chǎn)品方案中。但是,它在系統(tǒng)項目中卻占有巨大的地位。

為了保證服務(wù)的高可用,發(fā)現(xiàn)問題一定要即使,解決問題一定要迅速,所以生產(chǎn)環(huán)境一旦出現(xiàn)問題,預警系統(tǒng)就會通過郵件、短信甚至電話的方式實施多維轟炸模式,確保相關(guān)負責人不錯過每一個可能的bug。

預警系統(tǒng)判斷疑似bug大部分源于日志。比如某個微服務(wù)接口由于各種原因?qū)е骂l繁調(diào)用出錯,此時調(diào)用端會捕獲這樣的異常并打印ERROR級別的日志,當該錯誤日志達到一定次數(shù)出現(xiàn)的時候,就會觸發(fā)報警。

Spring Boot默認日志系統(tǒng)

Spring Boot默認使用LogBack日志系統(tǒng),如果不需要更改為其他日志系統(tǒng)如Log4j2等,則無需多余的配置,LogBack默認將日志打印到控制臺上。

新建的Spring Boot項目一般都會引用spring-boot-starter或者spring-boot-starter-web,而這兩個起步依賴中都已經(jīng)包含了對于spring-boot-starter-logging的依賴,所以,無需額外添加依賴

如何在項目中打印日志

新建一個配置類ConfigLog,注入一個Bean,并在方法中打印日志

package com.toec.util;
?
/**
 * @author : Jone
 * @date : 14:27 2021/8/18 0018
 * @function :
 */
import com.toec.business.entity.Person;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
?
?
?
/**
 * 配置內(nèi)部類
 */
@Configuration
public class ConfigLog {
?
    private static final Logger LOG = LoggerFactory.getLogger(ConfigLog.class);
?
    @Bean
    public Person logMethod() {
        LOG.info("==========print log==========");
        return new Person();
    }
}

Spring Boot默認的日志級別為INFO,這里打印的是INFO級別的日志所以可以顯示。

很多開發(fā)者在日常寫private static final Logger LOG = LoggerFactory.getLogger(LogConfig.class);總覺得后面的LogConfig.class可有可無,因為隨便寫個其他類也不會報錯,但是準確編寫class信息能夠提供快速定位日志的效率。

我們看到打印的日志內(nèi)容左側(cè)就是對應的類名稱,這個是通過private static final Logger LOG = LoggerFactory.getLogger(LogConfig.class);實現(xiàn)的。

如果將LogConfig.class換成xxx.class,輸出日志就會顯示對應的xxx類名。這樣聲明的好處就是方便定位日志。

如何將日志信息存儲到文件

在本機環(huán)境,我們習慣在控制臺看日志,但是線上我們還是要通過將日志信息保存到日志文件中,查詢?nèi)罩疚募纯伞?/p>

那么應該如何配置才能將日志信息保存到文件呢?

在我們創(chuàng)建的springboot-demo項目中,resources目錄下有個application.properties文件(如果是application.yml文件也是同樣的道理,只是采用的不同的編寫風格而已)。

添加如下配置

logging.path=/Users/jackie/workspace/rome/ 
logging.file=springbootdemo.log
  • logging.path

該屬性用來配置日志文件的路徑

  • logging.file

該屬性用來配置日志文件名,如果該屬性不配置,默認文件名為spring.log

如何設(shè)置日志級別

日志級別總共有TRACE < DEBUG < INFO < WARN < ERROR < FATAL ,且級別是逐漸提供,如果日志級別設(shè)置為INFO,則意味TRACE和DEBUG級別的日志都看不到。

上例中我們打印了一個INFO級別的日志,因為Spring Boot默認級別就是INFO,如果我們改為WARN,是否還能看到這行日志信息。

  • logging.level

該屬性用于配置日志級別。

在applicaition.properties中添加

logging.level.root=warn

這里是用的root級別,即項目的所有日志,我們也可以使用package級別,即指定包下使用相應的日志級別,下面再看。

可以改動root還是INFO級別,將指定包下的日志級別設(shè)置為WARN

logging.level.root=INFO
?
logging.level.com.jackie.springbootdemo.config=WARN

如何定制自己的日志格式

在application.properties中添加

logging.pattern.console=%d{yyyy/MM/dd-HH:mm:ss} [%thread] %-5level %logger- %msg%n 
logging.pattern.file=%d{yyyy/MM/dd-HH:mm} [%thread] %-5level %logger- %msg%n

logging.pattern.console

該屬性用于定制日志輸出格式。

上述配置的編碼中,對應符號的含義如下

  • %d{HH:mm:ss.SSS}——日志輸出時間
  • ?%thread——輸出日志的進程名字,這在Web應用以及異步任務(wù)處理中很有用
  • %-5level——日志級別,并且使用5個字符靠左對齊
  • %logger- ——日志輸出者的名字?
  • %msg——日志消息?
  • %n——平臺的換行符

最終輸出結(jié)果信息

2021-08-18 14:36:58.770  INFO 9200 --- [main] com.toec.LoginfoApplication              : Starting LoginfoApplication using Java 1.8.0_91 on WIN-SU66PB1OO5Q with PID 9200 (E:\IdeaProjects\WebFrameProject\loginfo\target\classes started by Administrator in E:\IdeaProjects\WebFrameProject\loginfo)
2021-08-18 14:36:58.774  INFO 9200 --- [main] com.toec.LoginfoApplication              : No active profile set, falling back to default profiles: default
2021-08-18 14:36:59.773  INFO 9200 --- [main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat initialized with port(s): 8088 (http)
2021-08-18 14:36:59.786  INFO 9200 --- [main] o.apache.catalina.core.StandardService   : Starting service [Tomcat]
2021-08-18 14:36:59.787  INFO 9200 --- [main] org.apache.catalina.core.StandardEngine  : Starting Servlet engine: [Apache Tomcat/9.0.50]
2021-08-18 14:36:59.925  INFO 9200 --- [main] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
2021-08-18 14:36:59.925  INFO 9200 --- [main] w.s.c.ServletWebServerApplicationContext : Root WebApplicationContext: initialization completed in 1101 ms
2021-08-18 14:36:59.997  INFO 9200 --- [main] com.toec.util.ConfigLog                  : ==========print log==========
2021-08-18 14:37:00.412  INFO 9200 --- [main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8088 (http) with context path ''
2021-08-18 14:37:00.423  INFO 9200 --- [main] com.toec.LoginfoApplication              : Started LoginfoApplication in 2.226 seconds (JVM running for 4.364)
2021/08/18-14:38 [main] INFO  com.toec.LoginfoApplication- Starting LoginfoApplication using Java 1.8.0_91 on WIN-SU66PB1OO5Q with PID 7272 (E:\IdeaProjects\WebFrameProject\loginfo\target\classes started by Administrator in E:\IdeaProjects\WebFrameProject\loginfo)
2021/08/18-14:38 [main] INFO  com.toec.LoginfoApplication- No active profile set, falling back to default profiles: default
2021/08/18-14:38 [main] INFO  org.springframework.boot.web.embedded.tomcat.TomcatWebServer- Tomcat initialized with port(s): 8088 (http)
2021/08/18-14:38 [main] INFO  org.apache.catalina.core.StandardService- Starting service [Tomcat]
2021/08/18-14:38 [main] INFO  org.apache.catalina.core.StandardEngine- Starting Servlet engine: [Apache Tomcat/9.0.50]
2021/08/18-14:38 [main] INFO  org.apache.catalina.core.ContainerBase.[Tomcat].[localhost].[/]- Initializing Spring embedded WebApplicationContext
2021/08/18-14:38 [main] INFO  org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext- Root WebApplicationContext: initialization completed in 975 ms
2021/08/18-14:38 [main] INFO  com.toec.util.ConfigLog- ==========print log==========
2021/08/18-14:38 [main] INFO  org.springframework.boot.web.embedded.tomcat.TomcatWebServer- Tomcat started on port(s): 8088 (http) with context path ''
2021/08/18-14:38 [main] INFO  com.toec.LoginfoApplication- Started LoginfoApplication in 1.899 seconds (JVM running for 4.747)

到此這篇關(guān)于關(guān)于Springboot的日志配置的文章就介紹到這了,更多相關(guān)Springboot日志配置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解決Lombok使用@Builder無法build父類屬性的問題

    解決Lombok使用@Builder無法build父類屬性的問題

    這篇文章主要介紹了解決Lombok使用@Builder無法build父類屬性的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • mapper.xml無法解析字段的問題

    mapper.xml無法解析字段的問題

    這篇文章主要介紹了mapper.xml無法解析字段的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • mybatis 多表關(guān)聯(lián)mapper文件寫法操作

    mybatis 多表關(guān)聯(lián)mapper文件寫法操作

    這篇文章主要介紹了mybatis 多表關(guān)聯(lián)mapper文件寫法操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • struts2中通過json傳值解決亂碼問題的實現(xiàn)方法

    struts2中通過json傳值解決亂碼問題的實現(xiàn)方法

    這篇文章主要介紹了struts2中通過json傳值解決亂碼問題的實現(xiàn)方法,涉及js編碼及java解碼的相關(guān)操作技巧,需要的朋友可以參考下
    2016-06-06
  • Java中監(jiān)聽器Listener詳解

    Java中監(jiān)聽器Listener詳解

    Listener是由Java編寫的WEB組件,主要完成對內(nèi)置對象狀態(tài)的變化 (創(chuàng)建、銷毀)和屬性的變化進行監(jiān)聽,做進一步的處理,主要對session和application內(nèi)置對象監(jiān)聽,這篇文章主要介紹了Java中監(jiān)聽器Listener,需要的朋友可以參考下
    2023-08-08
  • Spring設(shè)計模式中代理模式詳細講解

    Spring設(shè)計模式中代理模式詳細講解

    如何實現(xiàn)在不修改源碼的基礎(chǔ)上實現(xiàn)代碼功能的增強呢?spring為我們提供了代理模式。所謂的代理模式通俗來說就是一個中介,它給某一個對象提供一個代理對象,并由代理對象控制原對象的引用,從而實現(xiàn)在不修改源碼的基礎(chǔ)上實現(xiàn)代碼功能的增強
    2023-01-01
  • 詳解Spring MVC 集成EHCache緩存

    詳解Spring MVC 集成EHCache緩存

    本篇文章主要介紹了詳解Spring MVC 集成EHCache緩存,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • Java實例化的幾種方法總結(jié)

    Java實例化的幾種方法總結(jié)

    這篇文章主要介紹了Java實例化的幾種方法總結(jié)的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • java使用ZipInputStream實現(xiàn)讀取和寫入zip文件

    java使用ZipInputStream實現(xiàn)讀取和寫入zip文件

    zip文檔可以以壓縮格式存儲一個或多個文件,本文主要為大家詳細介紹了java如何使用ZipInputStream讀取Zip文檔與寫入,需要的小伙伴可以參考下
    2023-11-11
  • Spring使用Setter完成依賴注入方式

    Spring使用Setter完成依賴注入方式

    這篇文章主要介紹了Spring使用Setter完成依賴注入方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-09-09

最新評論