关于logBack配置日志文件及编码配置的问题
时间:2022-05-09 09:40:46|栏目:JAVA代码|点击: 次
记录下使用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版本的没有啥问题。
栏 目:JAVA代码
下一篇:spring boot 自定义参数过滤器,把传入的空字符转换成null方式
本文地址:http://www.codeinn.net/misctech/201416.html


阅读排行
- 1Java Swing组件BoxLayout布局用法示例
- 2java中-jar 与nohup的对比
- 3Java邮件发送程序(可以同时发给多个地址、可以带附件)
- 4Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.Type异常
- 5Java中自定义异常详解及实例代码
- 6深入理解Java中的克隆
- 7java读取excel文件的两种方法
- 8解析SpringSecurity+JWT认证流程实现
- 9spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐)
- 10深入解析java虚拟机




