从log4j日志无缝迁移至logback

Posted exmyth

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了从log4j日志无缝迁移至logback相关的知识,希望对你有一定的参考价值。

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的主要内容,如果未能解决你的问题,请参考以下文章

将项目从 log4j 迁移到 slf4j+log4j

阿里云ECS服务器跨账号无缝迁移

从 log4j 1.2.17 迁移后的 log4j 2.2 问题

如何将VMware主机上的虚拟机无缝迁移至Hyper-V平台

如何配置log4j2日志记录至数据库

log4j+slf4j管理日志项目迁移logback+slf4j