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 方法