log4j、slf4j、logback的关系剖析

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/chao821/article/details/84955118

一、日志框架接口与日志框架实现

slf4j是一系列日志的通用接口,实现日志记录功能时需要加载其他的日志框架实现jar包。log4j和logback是slf4j日志框架的两种实现,目前logback的效率较log4j更高一点。代码中记录日志的方式主要有两种:

1)调用slf4j日志系统的接口记录日志(通用性更高)

2)直接调用slf4j的相关实现类记录日志

对于第一种情况,slf4j的用法是"Logger logger = LoggerFactory.getLogger(Object.class);";对于第二种情况,需要直接调用不同日志框架实现类的方法记录日志,如log4j,可写为Logger logger = Logger.getLogger(Object.class);

二、log4j与logback的比较

log4j是apache实现的一个开源日志组件。(Wrapped implementations),logback同样是由log4j的作者设计完成的,拥有更好的特性,用来取代log4j的一个日志框架。是slf4j的原生实现。(Native implementations)。logback是直接实现了slf4j的接口,是不消耗内存和计算开销的。而log4j不是对slf4j的原生实现,所以slf4j api在调用log4j时需要一个适配层(slf4j-logj12)。

附录:

slf4j+log4jdemo:https://github.com/chao1991/log4j-slf4j

参考文档:

https://www.cnblogs.com/Sinte-Beuve/p/5758971.html

https://www.cnblogs.com/zhuawang/p/3999235.html

https://www.cnblogs.com/xrq730/p/8619156.html

猜你喜欢

转载自blog.csdn.net/chao821/article/details/84955118