首页 技术 正文
技术 2022年11月8日
0 收藏 638 点赞 1,884 浏览 3591 个字

1.Logger通过Logger类的静态方法Logger.getRootLogger得到RootLogger。所有其他的loggers是通过静态方法Logger.getLogger来实例化并获取的。这个方法Logger.getLogger把所想要的logger的名字作为参数。 Logger类的一些其它基本方法在下面列出:

package org.apache.log4j;public class Logger {  // Creation and retrieval methods:  public static Logger getRootLogger();  public static Logger getLogger(String name);   // printing methods:  public void debug(Object message);  public void info(Object message);  public void warn(Object message);  public void error(Object message);  public void fatal(Object message);   // generic printing method:  public void log(Level l, Object message);}

2. getLogger方法以一样的参数名字调用getLogger方法,返回的reference总是指向完全相同的logger对象。例如,在这里:

Logger x = Logger.getLogger(“wombat”);Logger y = Logger.getLogger(“wombat”);

x和y指向完全相同的logger对象。3.Log4j使用流程1)根据配置文件初始化log4j       log4j可以使用3种配置器来初始化:BasicConfigurator,DOMConfigurator,PropertyConfigurator。这里用的是PropertyConfigurator。使用PropertyConfigurator适用于所有的系统。如下的语句。

PropertyConfigurator.configure(“log4j.properties”);

就以log4j.properties为配置文件初始化好了log4j环境。对于一般的java project 可以不使用上面的语句初始化log4j,log4j会自动在classpath下,找到配置文件并初始化。如果log4j不能自动初始化配置文件,那么就需要用上面的方法进行初始化。       注意:初始化配置文件,最好只在系统启动的时候执行一次,如果执行多次,一是浪费资源,二就是对于老版本的log4j,使用DailyRollingFileAppender时,可能会出现问题。 2)导入org.apache.log4j.Logger;及相关包。 3)在需要使用log4j的地方获取Log实例。

private static Logger log = Logger.getLogger(“MyCLASS.class”);

 4)使用Logger对象的debug,info,fatal…方法。

log.debug(“it is the debug info”);

4.Log4j使用示例Test.java

import org.apache.log4j.Logger; public class Test {    static Logger log= Logger.getLogger(Test.class);    public void log(){       log.debug(“Debug info.”);       log.info(“Info info”);       log.warn(“Warn info”);       log.error(“Error info”);       log.fatal(“Fatal info”);    }    public static void main(String[] args) {       Test test = new Test();       test.log();    }}

 Log4j.properties(具体配置属性定义见《Log4j配置说明》)

log4j.rootLogger=info, stdoutlog4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.layout=org.apache.log4j.PatternLayout# Pattern to output the caller’s file name and line number.log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) – %m%n

 结果INFO [main] (Test.java:16) – Info infoWARN [main] (Test.java:17) – Warn infoERROR [main] (Test.java:18) – Error infoFATAL [main] (Test.java:19) – Fatal info 分析:Test.java“Logger.getLogger(Test.class);”这里的“Test.class”事实上传进去的是Test这个类的完整路径(包名+类名),“test.Test”。这样如果存在“test”这个Log那么Test这个Log就继承它,否则就继承rootLogger。 Log4j.properties第一行,配置log4j.rootLogger。应为它是根,必须配置,否则别的Log无法继承。其他的Log可以配置也可以不配置。等号后面的第一个参数表示日志级别,可以填五个级别中的一种(Log4j默认把日志信息分为五个等级debug < info < warn < error < fatal),后面的参数都是让Log知道输出到哪里,如果你想让日志输出到两个地方就加两个输出参数,比如:

log4j.rootLogger=info, stdout

这里的info表示,该Log的日志级别为info,所有级别小于info的日志都不会被记录。比如使用这个配置文件的话,我刚开始举的那个类中:

log.debug(“Debug info.”);

这句话是不起作用的,因为debug的级别小于info。这样就很容易控制什么信息在调试的时候要显示,什么信息在发布的时候要去掉。这些都不用改代码。      配置stdout,这个名字是随便取的,你可以叫它A:

log4j.appender.A=org.apache.log4j.ConsoleAppender

那么上面的rootLogger的参数stdout也要改成A,其他用到的地方当然也要改。这里的关键不是名字,而是appender类型,比如这里的“ConsoleAppender”,指输出到Console。后面两行都是设置日志格式的。5.Apache Log介绍集[1] Apache Log4j配置说明[2] Apache Log4j使用实例[3] Apache Commons-logging使用实例[4] 如何自建appender扩展Log4j框架6.参考资料[1] Log4j官方手册[2] Log4j最简入门http://afront.bokee.com/6157060.html

本文出自 “子 孑” 博客,请务必保留此出处http://zhangjunhd.blog.51cto.com/113473/21211

本文出自 51CTO.COM技术博客

WARN No appenders could be found for logger (org.springframework.web.context.ContextLoader).

 

错误现象:

提示如下:

log4j:WARN No appenders could be found for logger (org.springframework.context.ContextLoader). log4j:WARN Please initialize the log4j system properly. log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.

翻译过来是说:没有输出源给予logger(记录器)(org.springframework.context.ContextLoader).请初始化log4系统属性。

解决,这种情况肯能是没有添加log4j.properties到项目导致

相关:

logback logback.xml 常用配置详解

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,487
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,903
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,736
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,486
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,126
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,289