JAVAlogback日志管理詳解
1、問(wèn)題描述
關(guān)于java中的日志管理logback,去年寫(xiě)過(guò)關(guān)于logback介紹的文章,這次項(xiàng)目中又優(yōu)化了下,記錄下,希望能幫到需要的朋友。
2、解決方案
這次其實(shí)是碰到了一個(gè)問(wèn)題,一般的情況是,會(huì)單獨(dú)在linux上創(chuàng)建個(gè)用戶,線上和開(kāi)發(fā)環(huán)境一樣,這樣腳本中假如有相對(duì)目錄的話,也能保持一致,但是這次因?yàn)榫€上環(huán)境創(chuàng)建其他用戶有問(wèn)題,只能用root用戶操作,導(dǎo)致logback定義的目錄,開(kāi)發(fā)和線上不一致,線上是root/***,開(kāi)發(fā)環(huán)境沒(méi)有權(quán)限訪問(wèn)該目錄(開(kāi)發(fā)環(huán)境使用的普通用戶),所以logback的目錄,需要配置化,但是無(wú)法從application中獲取,換了個(gè)方式解決的,記錄下。
2.1 配置
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<springProperty scope="context" name="LOG_HOME" source="path.log"/>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
</encoder>
</appender>
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<FileNamePattern>${LOG_HOME}/laowangtest.%d{yyyy-MM-dd}.%i.log</FileNamePattern>
<MaxHistory>30</MaxHistory>
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<MaxFileSize>1kb</MaxFileSize>
<!-- <MaxFileSize>5MB</MaxFileSize>- -->
</timeBasedFileNamingAndTriggeringPolicy>
</rollingPolicy>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n</pattern>
</encoder>
</appender>
<!-- 日志輸出級(jí)別 -->
<root level="INFO">
<appender-ref ref="STDOUT" />
<appender-ref ref="FILE" />
</root>
</configuration>
簡(jiǎn)要說(shuō)明
1、目錄配置化
<springProperty scope="context" name="LOG_HOME" source="path.log"/>
其中application.yml中配置是這樣的:
path:
log: e:/laowang/test
實(shí)際項(xiàng)目中還有另外的配置文件:application-dev.yml、application-test.yml、application-prod.yml,path.log是配置在每個(gè)文件中,每個(gè)里面的值不一樣,而不是配置在公共配置application.yml中,這樣根據(jù)打包規(guī)則就能獲取不同的日志目錄了。
另外至于為什么無(wú)法通過(guò) 方 式 獲 取 值 , 網(wǎng) 上 或 者 官 方 給 的 答 案 是 , 在 容 器 中 , l o g b a c k 先 與 a p p l i c a t i o n . y m l 加 載 了 , 所 以 通 過(guò) {}方式獲取值,網(wǎng)上或者官方給的答案是,在容器中,logback先與application.yml加載了,所以通過(guò) 方式獲取值,網(wǎng)上或者官方給的答案是,在容器中,logback先與application.yml加載了,所以通過(guò){}方式就拿不到值了;同時(shí)保險(xiǎn)起見(jiàn),將logback.xml文件名稱更改為logback-***.xml,例如:logback-spring.xml。
2、簡(jiǎn)單介紹下目前的配置
配置了兩個(gè)Appender,一個(gè)打印到控制臺(tái),一個(gè)是到文件,以前把文件按照info、warn、errro,根據(jù)日志級(jí)別區(qū)分了打印文件,現(xiàn)在感覺(jué)沒(méi)必要,就打印一個(gè)里面去,還按照以前方式滾動(dòng),首先按天,其次按大小滾動(dòng)日志
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<FileNamePattern>${LOG_HOME}/laowangtest.%d{yyyy-MM-dd}.%i.log</FileNamePattern>
<MaxHistory>30</MaxHistory>
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<MaxFileSize>1kb</MaxFileSize>
<!-- <MaxFileSize>5MB</MaxFileSize>- -->
</timeBasedFileNamingAndTriggeringPolicy>
</rollingPolicy>
其中幾個(gè)參數(shù):
(1)FileNamePattern,文件目錄;
(2)MaxHistory:日志保留天數(shù);
(3)MaxFileSize:多大開(kāi)始滾動(dòng)(新增)日志,記得是5MB,后面還有B不要漏掉了。
2.2 效果
為了展示效果,把大小給成1kb滾動(dòng),弄個(gè)測(cè)試方法進(jìn)行驗(yàn)證
(1)測(cè)試方法
@Api(value = "test")
@RestController
public class TestController {
Logger logger = LoggerFactory.getLogger(TestController. class);
@RequestMapping(value ="/logTest")
@ResponseBody
public String logTest() {
logger.info("老王是帥哥老王是帥哥老王是帥哥");
return "老王是帥哥!";
}
}
(2)執(zhí)行效果
瀏覽器:

生成文件:

文件內(nèi)容:

總結(jié)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
詳解SpringMVC注解@initbinder解決類型轉(zhuǎn)換問(wèn)題
本篇文章主要介紹了詳解SpringMVC注解@initbinder解決類型轉(zhuǎn)換問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
時(shí)間處理函數(shù)工具分享(時(shí)間戳計(jì)算)
這篇文章主要介紹了時(shí)間處理函數(shù)工具,包括得到時(shí)間戳、周一、周末、時(shí)間更改、時(shí)間精確計(jì)算等功能2014-01-01
java實(shí)現(xiàn)簡(jiǎn)單撲克牌游戲
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡(jiǎn)單撲克牌游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-09-09
Springboot微服務(wù)打包Docker鏡像流程解析
這篇文章主要介紹了Springboot微服務(wù)打包Docker鏡像流程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08
MyBatis嵌套查詢collection報(bào)錯(cuò):org.apache.ibatis.exceptions.TooMany
本文主要介紹了MyBatis嵌套查詢collection報(bào)錯(cuò):org.apache.ibatis.exceptions.TooManyResultsException,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-09-09
jvm crash的崩潰日志詳細(xì)分析及注意點(diǎn)
本篇文章主要介紹了jvm crash的崩潰日志詳細(xì)分析及注意點(diǎn)。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-04-04
Java之SpringCloud nocos注冊(cè)中心講解
這篇文章主要介紹了Java之SpringCloud nocos注冊(cè)中心講解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08

