J2SE - 关于Commons-Logging、Slf4j、Log4j、Logback的整理

一、Commons-Logging

    是Apache提供的一个通用的日志接口。用户可以自由选择第三方的日志框架如Log4j作为具体实现。Commons-Logging通过动态查找的机制,在程序运行时自动找出真正使用的日志库。好处就是代码依赖是Common-Logging而Log4j,避免了和具体的日志方案直接耦合

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
 
public class Tst {
	private static Log logger = LogFactory.getLog(Tst.class);

    public void test(){
        logger.info("order. id=" + o.getId() + ".");
    }
}

二、Slf4j

    即简单日志门面(Simple Logging Facade for Java),类似于Commons-Logging,是对不同日志框架提供的一个门面封装,不同的是它是在编译时静态绑定真正的Log库。任何一种基于Slf4j的实现都要有一个绑定org.slf4j.impl.StaticLoggerBinder的类。如果有任意两个实现Slf4j的包同时出现就可能出现问题

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
 
public class Tst {
	private static final Logger logger = LoggerFactory.getLogger(Tst.class);

    public void test(){
        logger.info("order. id={}.", o.getId());
    }
}

三、Log4j

    是Apache的一个开放源日志框架,通过使用Log4j可以控制日志信息输送地是控制台、文件、GUI组件、套接口服务器等,也可以控制每一条日志的输出格式、定义每一条日志信息的级别等,这些都仅通过一个配置文件就可以灵活地进行配置而不需要修改程序代码

四、Logback

    是由Log4j创始人设计的又一个开源日记框架,将作为Log4j的替代和Slf4j组成新的日志系统的完整实现。Logback当前分成三个模块:Logback-Core是其它两个模块的基础模块;Logback-Classic是一个完整实现Slf4j Api的Log4j的改良版本;Logback-Access模块与Servlet容器集成提供通过Http来访问日志的功能

五、最后

    1、Commons-Logging 和 Slf4j只是一种日志抽象门面,不是具体的日志框架;Log4j 和 Logback是具体的日志框架 

    2、Slf4j支持参数化的Log字符串,避免了字符串拼接的麻烦和性能损耗;Logback的整体性能也比Log4j更佳

    3、一般首选使用Slf4j+Logback,或者Slf4j+Log4j、Commons-Logging+Log4j

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值