关于logBack配置日志文件及编码配置的问题

记录下使用logback中遇到的问题,方便以后查看

logback输出到文件文件大小设置问题

目前网上能搜到的关于输出到日志文件的大小设置有如下两种:

1.单独的triggeringPolicy标签

若rollingPolicy用SizeAndTimeBasedRollingPolicy,直接复制下面的triggeringPolicy会报错,说无法创建triggeringPolicy component。

<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

<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下添加标签:

<charset class="java.nio.charset.Charset">UTF-8</charset>

此方法使用后logback本身有报错,说无法识别charset配置

第二种方法:

<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版本的没有啥问题。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

空虚无聊的时候就读书,但一定得有自己的生活目标和计划。

关于logBack配置日志文件及编码配置的问题

相关文章:

你感兴趣的文章:

标签云: