`
pavel
  • 浏览: 914697 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Logger.getLogger和 LogFactory.getLog

阅读更多

Logger来自log4j自己的包。如果用Logger.getLogger,需要一个log4j的jar包,用此方式你只能依靠log4j:
而LogFactory来自common-logging包。如果用LogFactory.getLog,你可以用任何实现了通用日志接口的日志记录器替换log4j,而程序不受影响。apache的common-logging包是通用日志接口,通过这个中间层,你可以随便指定到底用哪个日志系统。增加系统的灵活性。若log4j它不存在, commons-logging 会另行选择其它的日志实现类。 这样保证了程序中不一定要使用log4j这个日志文件了
增强灵活性的理由:
  1)首先在 classpath 下寻找自己的配置文件 commons-logging.properties ,如果找到,则使用其中定义的 Log 实现类;

2) 如果找不到 commons-logging.properties 文件,则在查找是否已定义系统环境变量  org.apache.commons.logging.Log ,找到则使用其定义的 Log 实现类;

3)  否则,查看 classpath 中是否有 Log4j 的包,如果发现,则自动使用 Log4j 作为日志实现类;

4)   否则,使用 JDK 自身的日志实现类( JDK1.4 以后才有日志实现类);

5)   否则,使用 commons-logging 自己提供的一个简单的日志实现类 SimpleLog ;


为了简化配置 commons-logging ,一般不使用 commons-logging 的配置文件,也不设置与 commons-logging 相关的系统环境变量,而只需将 Log4j 的 Jar 包放置到 classpash 中就可以了。这样就很简单地完成了 commons-logging 与 Log4j 的融合。

根据不同的性质,日志信息通常被分成不同的级别,从低到高依次是:“调试( DEBUG )”“信息( INFO )”“警告( WARN )”“错误(ERROR )”“致命错误( FATAL )”。


基于common-logging的运行方式:
package org;
import org.apache.commons.logging.Log;
import org.apache.log4j.Logger;
public class Test extends TagSupport{
public static Logger log=Logger.getLogger(Test.class);
public static void test()
{
log.debug("111");
log.info("125");
log.warn("485");
log.error("error");

}
public static void main(String[] a)
{
Test.test();
}
}

基于log4j的运行方式
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
public class TestLog4j {

static Logger logger = Logger.getLogger(TestLog4j.class);
   public static void main(String args[]) {
   PropertyConfigurator.configure("log4j.properties");
   logger.debug("Here is some DEBUG");
   logger.info("Here is some INFO");
      logger.warn("Here is some WARN");
      logger.error("Here is some ERROR");
      logger.fatal("Here is some FATAL");
   }
}

-----------
commons-logging 仅仅对 Log4j( 当然还包括其它 LOG 实现 ) 作了一层包装,具体的日志输出还是在内部转交给身后的 Log4j 来处理,还有log4j会默认的去classes目录下去寻找log4j.properties 文件

分享到:
评论

相关推荐

    Logger.getLogger()和LogFactory.getLog()的区别

    Java日志管理:Logger.getLogger()和LogFactory.getLog()的区别,详解log4j

    Logger.getLogger与LogFactory.getLog

    NULL 博文链接:https://xinghaifeng2006.iteye.com/blog/1135913

    Logger.getLogger()与LogFactory.getLog()的区别详解

    LogFactory来自common-logging包。如果用LogFactory.getLog,你可以用任何实现了通用日志接口的日志记录器替换log4j,而程序不受影响

    simplelogger.properties

    simplelogger.properties

    golang日志处理库go-logger.zip

    打印日志有5个方法 Debug,Info,Warn, Error ,Fatal 日志级别由低到高设置日志级别的方法为:logger.SetLevel() 如:logger.SetLevel(logger.WARN)则:logger.Debug(....),logger.Info(...) 日志不会打出,而 ...

    如何使用LoggerFactory.getLogger在Spring Boot中输出日志(1)

    我们通过一个完整的实例和代码演示了如何在Spring Boot项目中获取Logger对象,并在控制器类中使用它来记录日志信息。 日志记录对于应用程序的健壮性和调试非常重要。使用SLF4J和适当的日志框架,开发者可以灵活地...

    log4j.properties

    log4j:WARN No appenders could be found for logger (org.apache.ibatis.logging.LogFactory). log4j:WARN Please initialize the log4j system properly. 将这个文件放到resources目录下,消除警告。

    python logging.info在终端没输出的解决

    补充知识:引用slf4j中Logger.info只打印出文字没有数据 引的是 slf4j 包 import org.slf4j.Logger; import org.slf4j.LoggerFactory; private static Logger logger = LoggerFactory.getLogger(Ts

    Notepad++ 插件,AndroidLogger.V1.2.7. 可以让安卓日志自动显示颜色

    Notepad++ 插件,AndroidLogger.V1.2.7. 可以让安卓日志自动显示颜色,告别白色背景 黑色字体!确保 打开的文件是.log后缀的。

    logger.js:Nodeio.js 的日志模块

    var logger = require ( './logger.js' ) ;logger . log ( "Log message" ) ;logger . error ( "Error message" ) ; // Logged to stderrlogger . warn ( "Warning message" ) ; // Logged to stderrlogger . info ...

    logger.h JNI的日志打印

    C++ Android Log

    Log4net详细说明使用

    这样就将信息同时输出到控制台和写入到文件名为“log-file.txt”的文件中,其中“log-file.txt”文件的路径是当前程序运行所在目录;也可以定义为绝对路径,配置如: <param name="File" value="C:/log-file.txt" />...

    简单golang日志Golog.zip

    logger.SetFlags(log.Ldate | log.Ltime | log.Lshortfile) // logger set log level logger.SetLevel(logger.INFO) logger.Debug("something", "debug") logger.Info("something") logger.Warn(...

    log4j-1.2.9

    static Logger log = Logger.getLogger(Main.class); public void print(){ log.debug("debug"); log.info("info"); log.warn("warn"); log.error("error"); log.fatal("fatal"); } public static ...

    Logger之Logger1

    Logger之Logger.getLogger(CLass) - CSDN博客原创2015年05月24日 12:17:25Logger之Logger.getLo

    Android代码-logger

    Logger.addLogAdapter(new AndroidLogAdapter()); And use Logger.d("hello"); Output Options Logger.d("debug"); Logger.e("error"); Logger.w("warning"); Logger.v("verbose"); Logger.i("information"); ...

    Logger日志文件查看

    .log文件查看, 日志文件查看 log工具,可以查看日志文件

    matlab logger.py

    matlab logger.py

    spring lib j2ee

    #log4j.logger.java.sql.Connection = INFO #log4j.logger.java.sql.Statement = DEBUG #log4j.logger.java.sql.PreparedStatement = DEBUG #log4j.logger.java.sql.ResultSet = DEBUG #2 定義A1輸出到控制器 ...

    weblogic jms

    Logger logger = Logger.getLogger(JMSQueueSend.class); public JMSQueueSend() { } public final static String JNDI_FACTORY = "weblogic.jndi.WLInitialContextFactory"; private static String JMS_...

Global site tag (gtag.js) - Google Analytics