理顺常用日志框架Commons-logging,slf4j,log4j,logback

Commons-loggin:是apache最早提供的日志的门面接口

SLF4j:是Simple Logging Facade for Java的简称,即java的简单日志门面。类似于Apache Common-Logging,是对不同日志框架提供的一个门面封装,他在编译时静态绑定真正的Log库

Log4j:通过使用Log4j,我们可以控制日志信息输送的目的地,是真正的实现日志输出的具体实现

logback:也是一种日志实现。Logback是由log4j创始人设计的又一个开源日记组件,LogBack被分为3个组件,logback-core, logback-classic 和 logback-access。logback-classic完整实现SLF4J API使你可以很方便地更换成其它日志系统如log4j或JDK14 Logging。logback比log4j更推荐使用

关系

commons-logging和slf4j是java中的日志门面,即它们提供了一套通用的接口,具体的实现可以由开发者自由选择。log4j和logback则是具体的日志实现方案。 

比较常用的搭配是commons-logging+log4j,slf4j+log4j

 

推荐使用 slf4j+log4j,优势在于有占位符{}替换,避免字符拼接消耗性能。

示例

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class TestLog {

    private static Log log = LogFactory.getLog(TestLog.class);

    private static Logger logger = LoggerFactory.getLogger(TestLog.class);

    public static void main(String[] args) {

        commonLog();
        slf4jLog();
    }

    public static void slf4jLog() {
        logger.info("rrtt:{}" , 112);
    }

    public static void commonLog() {
        log.info("rrtt:" + 112);
    }

}

logback

官网入口 https://logback.qos.ch/manual/introduction.html 

logback 对log4j进行了功能扩展,一般都用配置文件的形式进行使用

import org.slf4j.LoggerFactory;

import ch.qos.logback.classic.Level;


public class TestLog {

    
    private static ch.qos.logback.classic.Logger logger = 
            (ch.qos.logback.classic.Logger) LoggerFactory.getLogger(TestLog.class);
    
    
    public static void main(String[] args) {
        
        slf4jLog();
    }

    public static void slf4jLog() {
        logger.setLevel(Level.ERROR);
        logger.info("rrtt:{}" , 111);
        logger.setLevel(Level.INFO);
        logger.info("rrtt:{}" , 112);
    }

}

打印:TestLog - [rrtt:112],,org.slf4j.Logger 没有setLevel 方法

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值