一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術(shù)及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Spring Boot系列教程之日志配置

Spring Boot系列教程之日志配置

2021-06-11 13:49JackieZheng Java教程

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

前言

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

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

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

?
1
2
3
4
5
6
7
8
9
try {
 
調(diào)用某服務
 
} 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依賴的

?
1
2
<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項目,可以看到打印的日志信息如下。

Spring Boot系列教程之日志配置

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

如何在項目中打印日志

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
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系列教程之日志配置

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文件也是同樣的道理,只是采用的不同的編寫風格而已)。添加如下配置

?
1
2
logging.path=/users/jackie/workspace/rome/
logging.file=springbootdemo.log

logging.path

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

logging.file

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

運行springbootdemoapplication

Spring Boot系列教程之日志配置

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

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

Spring Boot系列教程之日志配置

如何設置日志級別

日志級別總共有tarce < debug < info < warn < error < fatal ,且級別是逐漸提供,如果日志級別設置為info,則意味trace和debug級別的日志都看不到。

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

logging.level

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

在applicaition.properties中添加

?
1
logging.level.root=warn

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

啟動springbootdemoapplication

Spring Boot系列教程之日志配置

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

這里我們可以改動root還是info級別,將指定包下的日志級別設置為warn

?
1
2
3
logging.level.root=info
 
logging.level.com.jackie.springbootdemo.config=warn

啟動springbootdemoapplication

Spring Boot系列教程之日志配置

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

如何定制自己的日志格式

在application.properties中添加

?
1
2
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應用以及異步任務處理中很有用

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

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

%msg——日志消息

%n——平臺的換行符

啟動springbootdemoapplication

Spring Boot系列教程之日志配置

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

總結(jié)

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

原文鏈接:https://www.cnblogs.com/bigdataZJ/p/springboot-log.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产视频二 | 亚洲免费高清视频 | 精品国产成人AV在线看 | 美女张开大腿让男人桶 | 含羞草传媒每天免费一次破解 | 亚洲网视频 | 1769最新资源站 | 性色香蕉AV久久久天天网 | a级成人毛片免费图片 | 精品网站| 免费观看俄罗斯特黄特色 | 国产亚洲精品久久yy5099 | 99视频有精品视频免费观看 | 久9视频这里只有精品123 | 近亲乱中文字幕 | 日韩免费一级片 | 午夜精品在线 | 草草视频免费看 | 久久AV喷吹AV高潮欧美 | 97青草 | 国产小青蛙 | 麻豆网站在线免费观看 | 免费特黄一区二区三区视频一 | 成人中文字幕在线高清 | v视界影院成片 | 果冻传媒天美传媒在线小视频播放 | 国产青色| 国产一区二区三区欧美 | jux629三浦理惠子在线播放 | 亚洲 无码 制服 日韩 | 97国产蝌蚪视频在线观看 | 九九九九九热 | 国产亚洲精品自在线亚洲情侣 | 日本大片网 | 色综合久久久 | 国产精品一区牛牛影视 | 91传媒制片厂果冻有限公司 | 草莓丝瓜芭乐樱桃榴莲色多黄 | 1717国产精品视频免费 | java hd国产高清| 欧美日韩精品一区二区三区高清视频 |