码迷,mamicode.com
首页 > 其他好文 > 详细

从log4j日志无缝迁移至logback

时间:2019-06-25 13:11:06      阅读:103      评论:0      收藏:0      [点我收藏+]

标签:log   static   repo   source   erro   成功   对比   ogg   下载地址   

logback对比log4j的有点在此就不赘述了。

由于在项目的原有代码中,大量的日志生成是通过log4j实现的,新的代码希望通过logback的方式生成日志,同时希望将老的代码在不修改的情况下直接将日志生成至logback指定配置中。

log4j迁移到logback 此文中介绍了一种迁移方式,但是需要修改代码,此种迁移风险太高。

《slf4j官方文档》传统桥接API 一文中介绍了使用log4j-over-slf4j.jar替代log4j.jar,通过桥接的方式将原有的日志生成至logback配置中。

log4j-over-slf4j.jar下载地址:Log4j Implemented Over SLF4J , Maven中央仓库信息速查

老的使用log4j生成日志代码

技术图片
package com.spike.test;

import java.io.IOException;
import java.sql.SQLException;

import org.apache.log4j.Logger;

public class Log4jExample {
       static Logger log = Logger.getLogger(Log4jExample.class.getName());
       
       public static void main(String[] args)throws IOException,SQLException{
          log.debug("Debug");
          log.info("Info");
          log.error("error");
          System.out.println(Log4jExample.class.getName()+" test");
       }
}
技术图片

将log4j-over-slf4j.jar导入至项目,排除log4j.jar,配置好使用logback需要的环境,日志生成至logback.xml配置指定的文件中

2016-11-03 14:14:31,799 [DEBUG] [main] com.spike.test.Log4jExample [LogbackExample.java : 18] Debug
2016-11-03 14:14:31,803 [INFO] [main] com.spike.test.Log4jExample [LogbackExample.java : 19] Info
2016-11-03 14:14:31,803 [ERROR] [main] com.spike.test.Log4jExample [LogbackExample.java : 20] error
com.spike.test.Log4jExample test

至此,在不改变代码的条件下迁移至logback成功。

但是发现一个小的问题,就是例如继承了HTMLLayout,Layout的类无法工作了。

 

技术图片

 

参考:

log4j-over-slf4j与slf4j-log4j12共存stack overflow异常分析

Log4j问题排查-log4j,logback到底用了哪个?

从log4j日志无缝迁移至logback

标签:log   static   repo   source   erro   成功   对比   ogg   下载地址   

原文地址:https://www.cnblogs.com/exmyth/p/11082224.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!