logBack配置日志文件及编码配置的示例分析

这篇文章主要介绍了logBack配置日志文件及编码配置的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

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

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

logBack配置日志文件及编码配置的示例分析

1.单独的triggeringPolicy标签

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

<rollingPolicyclass="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
              <fileNamePattern>tests.%i.log.zip</fileNamePattern>
              <minIndex>1</minIndex>
              <maxIndex>3</maxIndex>
            </rollingPolicy>

            <triggeringPolicyclass="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
              <maxFileSize>5MB</maxFileSize>
            </triggeringPolicy>

2.此种方式会有warning 说SizeAndTimeBasedFNATP是过时的了

请用最新的SizeBasedTriggeringPolicy

<rollingPolicyclass="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>E:/logs/mylog-%d{yyyy-MM-dd_HH-mm}.%i.log</fileNamePattern>
<maxHistory>5</maxHistory>

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

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

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

第二种方法:

<encoderclass="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<pattern>%d{yyyy-MM-ddHH:mm:ss.SSS}%-5level%loggerLine:%-3L-%msg%n</pattern>
<charset>utf-8</charset>
</encoder>

有的说此方式已经过时了,实际使用logback-core 1.2.3版本的没有啥问题。

感谢你能够认真阅读完这篇文章,希望小编分享的“logBack配置日志文件及编码配置的示例分析”这篇文章对大家有帮助,同时也希望大家多多支持恰卡编程网,关注恰卡编程网行业资讯频道,更多相关知识等着你来学习!

发布于 2021-07-29 21:58:41
收藏
分享
海报
0 条评论
187
上一篇:JAVA中ClassLoader.getResourceAsStream()与Class.getResourceAsSt 下一篇:Java和IDEA中文件打包的示例分析
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码