log4j迁移到logback的小插曲

这次把使用log4j的项目中的log4j都去掉了,统一使用logback。 就需要干掉下面下面两个jar包

log4j.jar
slf4j-log4j12.jar

由于项目中代码很多地方直接使用了log4j,所以需要引入 log4j-over-slf4j

这个包会和log4j冲突,必须全部排出掉log4j的包。

去掉log4j的配置文件,引入logback的包,加上logback的包和配置文件

logback-classic
logback-core
slf4j-api
log4j-over-slf4j

有个很有意思的插曲,上线后发现了一个很诡异的事情,日志输出的时间和服务器的北京时间相差了8小时,配置格式:

<Pattern>%d{yyyy-MM-dd HH:mm:ss,SSS} %-5p [%thread] %level - %m%n</Pattern>

这个配置如果使用log4j的话输出格式大致是这样的:

2019-01-20 23:00:00,621 INFO ......

如果放在logback的话,输出格式是这样的:

2019-01-22 13:00:00 INFO .....

正好相差8小时,且SSS没有输出

在logback里不支持pattern的时间格式使用逗号进行分割,所以使用,是不行的,而log4j是可以的。 将逗号换成点的写法就好了。

改为:

<Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %-5p [%thread] %level - %m%n</Pattern>

日志输出变为为:

2019-01-20 23:00:00.621 INFO ......

老的代码前人使用了不规范的写法,后人进行更改的时候没有注意到这个小细节导致了日志时间出现问题。

这个问题之所以在测试环境没有被发现是因为只有特定的日志打印才会使用这个Pattern的格式输出日志,且日志量极少。

转载于:https://my.oschina.net/110NotFound/blog/3004541

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值