记录下使用logback中遇到的问题,方便以后查看
logback输出到文件文件大小设置问题
目前网上能搜到的关于输出到日志文件的大小设置有如下两种:
1.单独的triggeringPolicy标签
若rollingPolicy用SizeAndTimeBasedRollingPolicy,直接复制下面的triggeringPolicy会报错,说无法创建triggeringPolicy component。
1
2
3
4
5
6
7
8
9
|
< rollingPolicy class = "ch.qos.logback.core.rolling.FixedWindowRollingPolicy" >
< fileNamePattern >tests.%i.log.zip</ fileNamePattern >
< minIndex >1</ minIndex >
< maxIndex >3</ maxIndex >
</ rollingPolicy >
< triggeringPolicy class = "ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy" >
< maxFileSize >5MB</ maxFileSize >
</ triggeringPolicy >
|
2.此种方式会有warning 说SizeAndTimeBasedFNATP是过时的了
请用最新的SizeBasedTriggeringPolicy
1
2
3
4
5
6
7
8
|
< rollingPolicy class = "ch.qos.logback.core.rolling.TimeBasedRollingPolicy" >
< fileNamePattern >E:/logs/mylog-%d{yyyy-MM-dd_HH-mm}.%i.log</ fileNamePattern >
< maxHistory >5</ maxHistory >
< timeBasedFileNamingAndTriggeringPolicy class = "ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP" >
< maxFileSize >100MB</ maxFileSize >
</ timeBasedFileNamingAndTriggeringPolicy >
</ rollingPolicy >
|
目前自己用的是一种比较简单的方法:
tests.%i.log.zip
30
10MB
如果完全按照第一种方法里的贴进去应该也是没问题的。
设置日志文件输出编码格式
网上logback.xml配置的很多,但大部分都不包含输出编码设置的,而logback默认输出到文件的编码格式是ANSI的,所以.java里是UTF-8没有问题的输出到日志里却成了乱码。
网上搜到的第一种方式是:
append下添加标签:
1
|
< charset class = "java.nio.charset.Charset" >UTF-8</ charset >
|
此方法使用后logback本身有报错,说无法识别charset配置
第二种方法:
1
2
3
4
|
< encoder class = "ch.qos.logback.classic.encoder.PatternLayoutEncoder" >
< pattern >%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level %logger Line:%-3L - %msg%n</ pattern >
< charset >utf-8</ charset >
</ encoder >
|
有的说此方式已经过时了,实际使用logback-core 1.2.3版本的没有啥问题。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/wangyoujian111/article/details/88392037