使用logback配置按天和文件大小切割輸出日志
logback配置按天和文件大小切割輸出日志
發(fā)現(xiàn)問(wèn)題
項(xiàng)目配置了按天輸出日志,最近查看日志文件,發(fā)現(xiàn)只有輸出項(xiàng)目重啟當(dāng)天日期文件名的日志,原先的日志配置:
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <!--設(shè)置策略--> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!--日志文件路徑:這里%d{yyyyMMdd}表示按天分類日志--> <FileNamePattern>${LOG_HOME}/%d{yyyyMMdd}.log</FileNamePattern> <!--日志保留天數(shù)--> <MaxHistory>30</MaxHistory> </rollingPolicy> <!--設(shè)置格式--> <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> <!--格式化輸出:%d表示日期,%thread表示線程名,%-5level:級(jí)別從左顯示5個(gè)字符寬度%msg:日志消息,%n是換行符--> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS}- %msg%n</pattern> <!-- 或者使用默認(rèn)配置 --> <!--<pattern>${FILE_LOG_PATTERN}</pattern>--> <charset>utf8</charset> </encoder> <!--日志文件最大的大小--> <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy"> <MaxFileSize>10MB</MaxFileSize> </triggeringPolicy> </appender>
分析問(wèn)題
rollingPolicy 設(shè)置基于時(shí)間的滾動(dòng)切割策略TimeBasedRollingPolicy輸出日志
但是里面包含了觸發(fā)策略triggeringPolicy
限制文件大小的SizeBasedTriggeringPolicy,這兩個(gè)策略不能一起組合使用
解決問(wèn)題
按需修改為基于時(shí)間和文件大小的組合策略SizeAndTimeBasedRollingPolicy:
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <!--設(shè)置策略--> <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"> <!--日志文件路徑:這里%d{yyyyMMdd}表示按天分類日志--> <!--%i 是切割序號(hào)--> <FileNamePattern>${LOG_HOME}/%d{yyyyMMdd}.%i.log</FileNamePattern> <!--日志保留天數(shù)--> <MaxHistory>30</MaxHistory> <!--日志文件最大的大小--> <maxFileSize>10MB</maxFileSize> </rollingPolicy> <!--設(shè)置格式--> <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> <!--格式化輸出:%d表示日期,%thread表示線程名,%-5level:級(jí)別從左顯示5個(gè)字符寬度%msg:日志消息,%n是換行符--> <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS}- %msg%n</pattern> <!-- 或者使用默認(rèn)配置 --> <!--<pattern>${FILE_LOG_PATTERN}</pattern>--> <charset>utf8</charset> </encoder> </appender>
logback設(shè)置按天,文件切割大小,總共日志文件大小
<?xml version="1.0" encoding="UTF-8"?> <configuration> <!-- 說(shuō)明: 1、日志級(jí)別及文件 日志記錄采用分級(jí)記錄,級(jí)別與日志文件名相對(duì)應(yīng),不同級(jí)別的日志信息記錄到不同的日志文件中 例如:error級(jí)別記錄到log_error_xxx.log或log_error.log(該文件為當(dāng)前記錄的日志文件),而log_error_xxx.log為歸檔日志, 日志文件按日期記錄,同一天內(nèi),若日志文件大小等于或大于2M,則按0、1、2...順序分別命名 例如log-level-2013-12-21.0.log 其它級(jí)別的日志也是如此。 2、文件路徑 若開(kāi)發(fā)、測(cè)試用,在Eclipse中運(yùn)行項(xiàng)目,則到Eclipse的安裝路徑查找logs文件夾,以相對(duì)路徑../logs。 若部署到Tomcat下,則在Tomcat下的logs文件中 3、Appender FILEERROR對(duì)應(yīng)error級(jí)別,文件名以log-error-xxx.log形式命名 FILEWARN對(duì)應(yīng)warn級(jí)別,文件名以log-warn-xxx.log形式命名 FILEINFO對(duì)應(yīng)info級(jí)別,文件名以log-info-xxx.log形式命名 FILEDEBUG對(duì)應(yīng)debug級(jí)別,文件名以log-debug-xxx.log形式命名 stdout將日志信息輸出到控制上,為方便開(kāi)發(fā)測(cè)試使用 --> <contextName>energy-platform</contextName> <property name="LOG_PATH" value="/var/log/userService" /> <!--設(shè)置系統(tǒng)日志目錄--> <property name="APPDIR" value="energy-platform" /> <!-- 日志記錄器,日期滾動(dòng)記錄 --> <appender name="FILEERROR" class="ch.qos.logback.core.rolling.RollingFileAppender"> <!-- 正在記錄的日志文件的路徑及文件名 --> <file>${LOG_PATH}/${APPDIR}/log_error.log</file> <!-- 日志記錄器的滾動(dòng)策略,按日期,按大小記錄 --> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!-- 歸檔的日志文件的路徑,例如今天是2013-12-21日志,當(dāng)前寫(xiě)的日志文件路徑為file節(jié)點(diǎn)指定,可以將此文件與file指定文件路徑設(shè)置為不同路徑,從而將當(dāng)前日志文件或歸檔日志文件置不同的目錄。 而2013-12-21的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 --> <fileNamePattern>${LOG_PATH}/${APPDIR}/error/log-error-%d{yyyy-MM-dd}.%i.log</fileNamePattern> <!-- 除按日志記錄之外,還配置了日志文件不能超過(guò)2M,若超過(guò)2M,日志文件會(huì)以索引0開(kāi)始, 命名日志文件,例如log-error-2013-12-21.0.log --> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>10MB</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> <!-- 追加方式記錄日志 --> <append>true</append> <!-- 日志文件的格式 --> <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> <pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level [%X{requestId}] %logger Line:%-3L - %msg%n</pattern> <charset>utf-8</charset> </encoder> <!-- 此日志文件只記錄info級(jí)別的 --> <filter class="ch.qos.logback.classic.filter.LevelFilter"> <level>error</level> <onMatch>ACCEPT</onMatch> <onMismatch>DENY</onMismatch> </filter> </appender> <!-- 日志記錄器,日期滾動(dòng)記錄 --> <appender name="FILEWARN" class="ch.qos.logback.core.rolling.RollingFileAppender"> <!-- 正在記錄的日志文件的路徑及文件名 --> <file>${LOG_PATH}/${APPDIR}/log_warn.log</file> <!-- 日志記錄器的滾動(dòng)策略,按日期,按大小記錄 --> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!-- 歸檔的日志文件的路徑,例如今天是2013-12-21日志,當(dāng)前寫(xiě)的日志文件路徑為file節(jié)點(diǎn)指定,可以將此文件與file指定文件路徑設(shè)置為不同路徑,從而將當(dāng)前日志文件或歸檔日志文件置不同的目錄。 而2013-12-21的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 --> <fileNamePattern>${LOG_PATH}/${APPDIR}/warn/log-warn-%d{yyyy-MM-dd}.%i.log</fileNamePattern> <!-- 除按日志記錄之外,還配置了日志文件不能超過(guò)2M,若超過(guò)2M,日志文件會(huì)以索引0開(kāi)始, 命名日志文件,例如log-error-2013-12-21.0.log --> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>10MB</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> <!-- 追加方式記錄日志 --> <append>true</append> <!-- 日志文件的格式 --> <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> <pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level [%X{requestId}] %logger Line:%-3L - %msg%n</pattern> <charset>utf-8</charset> </encoder> <!-- 此日志文件只記錄info級(jí)別的 --> <filter class="ch.qos.logback.classic.filter.LevelFilter"> <level>warn</level> <onMatch>ACCEPT</onMatch> <onMismatch>DENY</onMismatch> </filter> </appender> <!-- 日志記錄器,日期滾動(dòng)記錄 --> <appender name="FILEINFO" class="ch.qos.logback.core.rolling.RollingFileAppender"> <!-- 正在記錄的日志文件的路徑及文件名 --> <file>${LOG_PATH}/${APPDIR}/log_info.log</file> <!-- 日志記錄器的滾動(dòng)策略,按日期,按大小記錄 --> <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy"> <!-- 歸檔的日志文件的路徑,例如今天是2013-12-21日志,當(dāng)前寫(xiě)的日志文件路徑為file節(jié)點(diǎn)指定,可以將此文件與file指定文件路徑設(shè)置為不同路徑,從而將當(dāng)前日志文件或歸檔日志文件置不同的目錄。 而2013-12-21的日志文件在由fileNamePattern指定。%d{yyyy-MM-dd}指定日期格式,%i指定索引 --> <fileNamePattern>${LOG_PATH}/${APPDIR}/info/log-info-%d{yyyy-MM-dd}.%i.log</fileNamePattern> <!-- 除按日志記錄之外,還配置了日志文件不能超過(guò)2M,若超過(guò)2M,日志文件會(huì)以索引0開(kāi)始, 命名日志文件,例如log-error-2013-12-21.0.log --> <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP"> <maxFileSize>10MB</maxFileSize> </timeBasedFileNamingAndTriggeringPolicy> </rollingPolicy> <!-- 追加方式記錄日志 --> <append>true</append> <!-- 日志文件的格式 --> <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder"> <pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level [%X{requestId}] %logger Line:%-3L - %msg%n</pattern> <charset>utf-8</charset> </encoder> <!-- 此日志文件只記錄info級(jí)別的 --> <filter class="ch.qos.logback.classic.filter.LevelFilter"> <level>info</level> <onMatch>ACCEPT</onMatch> <onMismatch>DENY</onMismatch> </filter> </appender> <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> <!--encoder 默認(rèn)配置為PatternLayoutEncoder--> <encoder> <pattern>===%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level [%X{requestId}] %logger Line:%-3L - %msg%n</pattern> <charset>utf-8</charset> </encoder> <!--此日志appender是為開(kāi)發(fā)使用,只配置最底級(jí)別,控制臺(tái)輸出的日志級(jí)別是大于或等于此級(jí)別的日志信息--> <filter class="ch.qos.logback.classic.filter.ThresholdFilter"> <level>debug</level> </filter> </appender> <logger name="org.springframework" level="WARN" /> <logger name="org.hibernate" level="WARN" /> <!-- 生產(chǎn)環(huán)境下,將此級(jí)別配置為適合的級(jí)別,以免日志文件太多或影響程序性能 --> <root level="INFO"> <appender-ref ref="FILEERROR" /> <appender-ref ref="FILEWARN" /> <appender-ref ref="FILEINFO" /> <!-- 生產(chǎn)環(huán)境將請(qǐng)stdout,testfile去掉 --> <appender-ref ref="STDOUT" /> </root> </configuration>
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- Springboot Logback日志多文件輸出方式(按日期和大小分割)
- logback?OutputStreamAppender高效日志輸出源碼解析
- java使用Logback配置輸出日志內(nèi)容到文件示例代碼
- logback自定義json日志輸出示例詳解
- Slf4j+logback實(shí)現(xiàn)JSON格式日志輸出方式
- logback過(guò)濾部分日志輸出的操作
- logback輸出日志屏蔽quartz的debug等級(jí)日志方式
- dubbo 如何使用logback來(lái)輸出日志
- springboot使用Logback把日志輸出到控制臺(tái)或輸出到文件
- Logback如何將日志輸出到Kafka配置示例
相關(guān)文章
springboot項(xiàng)目中出現(xiàn)同名bean異常報(bào)錯(cuò)的解決方法
這篇文章給大家聊聊springboot項(xiàng)目出現(xiàn)同名bean異常報(bào)錯(cuò)如何修復(fù),文中通過(guò)代碼示例給大家介紹解決方法非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-01-01Mybatis數(shù)據(jù)批量插入如何實(shí)現(xiàn)
這篇文章主要介紹了Mybatis數(shù)據(jù)批量插入如何實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07Java快速入門(mén)掌握類與對(duì)象及變量的使用
類和對(duì)象是兩種以計(jì)算機(jī)為載體的計(jì)算機(jī)語(yǔ)言的合稱。對(duì)象是對(duì)客觀事物的抽象,類是對(duì)對(duì)象的抽象。類是一種抽象的數(shù)據(jù)類型;變量就是可以變化的量,存儲(chǔ)在內(nèi)存中—個(gè)可以擁有在某個(gè)范圍內(nèi)的可變存儲(chǔ)區(qū)域2022-04-04關(guān)于String轉(zhuǎn)Json的幾種方式
這篇文章主要介紹了關(guān)于String轉(zhuǎn)Json的幾種方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-12-12