欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring Boot系列教程之日志配置

 更新時間:2018年11月12日 14:48:49   作者:JackieZheng  
這篇文章主要給大家介紹了關(guān)于Spring Boot系列教程之日志配置的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

日志,通常不會在需求階段作為一個功能單獨提出來,也不會在產(chǎn)品方案中看到它的細節(jié)。但是,這絲毫不影響它在任何一個系統(tǒng)中的重要的地位。

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

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

try {

調(diào)用某服務(wù)

} catch(Exception e) {

LOG.error("錯誤信息", e);

}

所以日志至關(guān)重要,這篇就來介紹下在Spring Boot如何配置日志。

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

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

如果要使用LogBack,原則上是需要添加dependency依賴的

<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId></pre>

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

我們基于《沒做過大項目,但我會建大項目》中創(chuàng)建的項目,啟動springboot-demo項目,可以看到打印的日志信息如下。

以上至默認配置啟動下的日志顯示情況,如果需要做一些定制的日志配置比如將日志存儲到文件等應(yīng)該如何配置,下面就通過幾個小問題來看看Spring Boot下是如何解決這些問題的。

如何在項目中打印日志

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

package com.jackie.springbootdemo.config;

import com.jackie.springbootdemo.model.Person;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration public class LogConfig {
private static final Logger LOG = LoggerFactory.getLogger(LogConfig.class);

@Bean
public Person logMethod() {
LOG.info("==========print log==========");
return new Person();
}
}

運行SpringBootDemoApplication,可以看到控制臺的日志

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

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

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

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

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

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

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

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

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

logging.path

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

logging.file

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

運行SpringBootDemoApplication

可以看到在指定路徑下生成了springbootdemo.log文件,該文件內(nèi)容和控制臺打印內(nèi)容一致。

如果注釋logging.file=springbootdemo.log則生成默認文件名spring.log

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

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

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

logging.level

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

在applicaition.properties中添加

logging.level.root=warn

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

啟動SpringBootDemoApplication

你沒看錯,這個項目是成功啟動了,但是幾乎沒有內(nèi)容,這是因為之前打印的日志級別都是INFO,這里設(shè)置為WARN,所以INFO級別的日志都不顯示。

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

logging.level.root=INFO

logging.level.com.jackie.springbootdemo.config=WARN

啟動SpringBootDemoApplication

可以看到除了LogConfig類中的INFO級別的日志沒有打印出來,其他的INFO級別的日志都正常輸出了。

如何定制自己的日志格式

在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

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

上述配置的編碼中,對應(yīng)符號的含義如下

%d{HH:mm:ss.SSS}——日志輸出時間

%thread——輸出日志的進程名字,這在Web應(yīng)用以及異步任務(wù)處理中很有用

%-5level——日志級別,并且使用5個字符靠左對齊

%logger- ——日志輸出者的名字

%msg——日志消息

%n——平臺的換行符

啟動SpringBootDemoApplication

限于篇幅,還有相關(guān)特性,這里不一一陳述了。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • 正確遍歷刪除List中的元素方法(推薦)

    正確遍歷刪除List中的元素方法(推薦)

    下面小編就為大家?guī)硪黄_遍歷刪除List中的元素方法(推薦)。小編覺得挺不錯的,在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • SpringCloud Feign傳遞HttpServletRequest對象流程

    SpringCloud Feign傳遞HttpServletRequest對象流程

    HttpServletRequest接口的對象代表客戶端的請求,當客戶端通過HTTP協(xié)議訪問Tomcat服務(wù)器時,HTTP請求中的所有信息都封裝在HttpServletRequest接口的對象中,這篇文章介紹了Feign傳遞HttpServletRequest對象的流程,感興趣的同學(xué)可以參考下文
    2023-05-05
  • java中FileOutputStream中文亂碼問題解決辦法

    java中FileOutputStream中文亂碼問題解決辦法

    這篇文章主要介紹了java中FileOutputStream中文亂碼問題解決辦法的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • 淺談String類型如何轉(zhuǎn)換為time類型存進數(shù)據(jù)庫

    淺談String類型如何轉(zhuǎn)換為time類型存進數(shù)據(jù)庫

    這篇文章主要介紹了String類型如何轉(zhuǎn)換為time類型存進數(shù)據(jù)庫,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 淺談@mapper引入不到引入的是@MapperScan的問題

    淺談@mapper引入不到引入的是@MapperScan的問題

    這篇文章主要介紹了淺談@mapper引入不到引入的是@MapperScan的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • 基于Javamail實現(xiàn)發(fā)送郵件(QQ/網(wǎng)易郵件服務(wù)器)

    基于Javamail實現(xiàn)發(fā)送郵件(QQ/網(wǎng)易郵件服務(wù)器)

    這篇文章主要介紹了基于Javamail實現(xiàn)發(fā)送郵件,分別使用QQ郵箱作為smtp郵件服務(wù)器發(fā)送郵件,使用網(wǎng)易郵箱作為smtp郵件服務(wù)器發(fā)送郵件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • java實現(xiàn)遍歷Map的方法

    java實現(xiàn)遍歷Map的方法

    這篇文章主要介紹了java實現(xiàn)遍歷Map的方法,以簡單實例形式分析了java針對HashMap的遍歷技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-09-09
  • Java map存放數(shù)組并取出值代碼詳解

    Java map存放數(shù)組并取出值代碼詳解

    這篇文章主要介紹了Java map存放數(shù)組并取出值代碼詳解的相關(guān)內(nèi)容,小編覺得挺不錯的,這里給大家分享一下,需要的朋友可以參考。
    2017-10-10
  • 教你如何使用Java實現(xiàn)WebSocket

    教你如何使用Java實現(xiàn)WebSocket

    這篇文章主要介紹了教你如何使用Java實現(xiàn)WebSocket問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • java如何用正則表達式匹配與提取字符串

    java如何用正則表達式匹配與提取字符串

    一位以前的同事在群里面突然發(fā)了個需求,要通過正則表達式來取值,下面這篇文章主要給大家介紹了關(guān)于java如何用正則表達式匹配與提取字符串的相關(guān)資料,需要的朋友可以參考下
    2022-06-06

最新評論