原文出处为:http://blog.csdn.net/caolaosanahnu/article/details/6771075
1, http://jmut.bokee.com/2400987.html
log4j.rootCategory
- 是对根类的设置,如不说明,以下的子类都要继承这些设置
log4j.category.*
- 是对自定义类的设置,可以对类、包和工程单独设置
Category的家族关系是通过“.”来说明的,比如x是x.y的父类。
默认情况下,子类要继承父类的全部设置,比如:
- log4j.rootCategory=INFO, dest1
- log4j.category.MyCategory=DEBUG
- dest1会输出INFO以上的消息
- 对于Category logger = Category.getInstance("MyCategory")会输出DEBUG以上的消息,因为MyCategory继承了根类的设置,输出到dest1
如果使用下面的设置,每条消息会在dest1中输出两次:
- log4j.rootCategory = INFO, dest1
- log4j.category.MyCategory = DEBUG, dest1
记住,MyCategory继承了根类的设置。
可以指定子类不继承父类的设置,方法是指定log4j.additivity.*=false,如上例中:
- log4j.rootCategory = INFO, dest1
- log4j.additivity.MyCategory = false
- log4j.category.MyCategory = DEBUG, dest1
2,http://wangjc-opal.iteye.com/blog/309924
log4j的强大功能无可置疑,但实际应用中免不了遇到某个功能需要输出独立的日志文件的情况,怎样才能把所需的内容从原有日志中分离,形成单独的日志文件呢?其实只要在现有的log4j基础上稍加配置即可轻松实现这一功能。
先看一个常见的log4j.properties文件,它是在控制台和myweb.log文件中记录日志:
log4j.rootLogger=DEBUG, stdout, logfile
log4j.category.org.springframework=ERROR
log4j.category.org.apache=INFO
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - %m%n
log4j.appender.logfile=org.apache.log4j.RollingFileAppender
log4j.appender.logfile.File=${myweb.root}/WEB-INF/log/myweb.log
log4j.appender.logfile.MaxFileSize=512KB
log4j.appender.logfile.MaxBackupIndex=5
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%d %p [%c] - %m%n
如果想对不同的类输出不同的文件(以cn.com.Test为例),先要在Test.java中定义:
private static Log logger = LogFactory.getLog(Test.class);
然后在log4j.properties中加入:
log4j.logger.cn.com.Test= DEBUG, test
log4j.appender.test=org.apache.log4j.FileAppender
log4j.appender.test.File=${myweb.root}/WEB-INF/log/test.log
log4j.appender.test.layout=org.apache.log4j.PatternLayout
log4j.appender.test.layout.ConversionPattern=%d %p [%c] - %m%n
也就是让cn.com.Test中的logger使用log4j.appender.test所做的配置。
但是,如果在同一类中需要输出多个日志文件呢?其实道理是一样的,先在Test.java中定义:
private static Log logger1 = LogFactory.getLog("myTest1");
private static Log logger2 = LogFactory.getLog("myTest2");
然后在log4j.properties中加入:
log4j.logger.myTest1= DEBUG, test1
log4j.appender.test1=org.apache.log4j.FileAppender
log4j.appender.test1.File=${myweb.root}/WEB-INF/log/test1.log
log4j.appender.test1.layout=org.apache.log4j.PatternLayout
log4j.appender.test1.layout.ConversionPattern=%d %p [%c] - %m%n
log4j.logger.myTest2= DEBUG, test2
log4j.appender.test2=org.apache.log4j.FileAppender
log4j.appender.test2.File=${myweb.root}/WEB-INF/log/test2.log
log4j.appender.test2.layout=org.apache.log4j.PatternLayout
log4j.appender.test2.layout.ConversionPattern=%d %p [%c] - %m%n
也就是在用logger时给它一个自定义的名字(如这里的"myTest1"),然后在log4j.properties中做出相应配置即可。别忘了不同日志要使用不同的logger(如输出到test1.log的要用logger1.info("abc"))。
还有一个问题,就是这些自定义的日志默认是同时输出到log4j.rootLogger所配置的日志中的,如何能只让它们输出到自己指定的日志中呢?别急,这里有个开关:
log4j.additivity.myTest1 = false
它用来设置是否同时输出到log4j.rootLogger所配置的日志中,设为false就不会输出到其它地方啦!注意这里的"myTest1"是你在程序中给logger起的那个自定义的名字!
如果你说,我只是不想同时输出这个日志到log4j.rootLogger所配置的logfile中,stdout里我还想同时输出呢!那也好办,把你的log4j.logger.myTest1 = DEBUG, test1改为下式就OK啦!
相关推荐
log4j.category.DEBUG2=DEBUG2, CustomAppender log4j.appender.DEBUG2=org.apache.log4j.FileAppender log4j.appender.DEBUG2.File=debug2.log log4j.appender.DEBUG2.layout=org.apache.log4j.PatternLayout log4j...
log4j.rootCategory=warn, R # 输出到控制台 log4j.appender.R=org.apache.log4j.ConsoleAppender # 控制台输出格式:简单布局 log4j.appender.R.layout=org.apache.log4j.SimpleLayout # 定义一个特殊的日志类别...
通过对Log4j配置文件的理解和自定义日志类的编写,我们可以实现对Struts、iBatis等框架的日志输出控制,同时也能根据项目需求进行灵活的日志输出。这种扩展不仅可以提高系统的可维护性和可调试性,还能有效地帮助...
Log4j 是一款广泛使用的日志记录框架,尤其在Java应用程序中非常常见。它提供了灵活的日志配置,允许开发者根据需要调整日志级别、输出格式和目标。在本文中,我们将详细探讨Log4j的配置文件,包括.properties和.xml...
- `log4j.additivity.org.apache=true`: 此配置表示 org.apache 包下的所有类的日志输出都会按照默认的 rootLogger 的配置进行记录,而不是只按照 org.apache 下的单独配置。 **2. Socket Appender** - 用于通过...
log4j.additivity.org.apache=true ``` 此配置表明对于名为`org.apache`的包下的所有类的日志输出,都将遵循root logger的配置。如果设置为`false`,则该包下的类会使用自己的单独配置。 **3. Console Appender** ...
Log4j是一个广泛使用的日志记录框架,它允许开发者对应用程序进行详细的日志记录,以帮助调试、性能分析和故障排查。在某些情况下,我们希望将不同模块的日志信息输出到不同的文件中,以便于管理和分析。以下是实现...
Log4j 是一个广泛使用的 Java 日志框架,它允许开发者控制和管理应用程序的日志输出。在不同的操作系统如 Linux、Mac 和 Windows 上,设置 Log4j 的日志文件存放位置是非常重要的,因为它可以帮助我们更好地组织和...
配置文件(如test_log4cpp2.conf)用于定义Category和Appender的关系,设置日志级别和输出策略。例如,rootCategory设置全局日志级别,而category.sub1等定义子类别及其关联的Appender。 7. **日志回滚与切割**: ...
Log4cpp是基于Apache的Log4j项目开发的,它遵循了Log4j的设计理念,提供了一个灵活、可扩展的日志框架。这个库的主要目标是使日志记录过程简单而高效,允许开发者根据需要调整日志级别,选择不同的日志输出目的地,...
log4j.category.SecurityLogger=${hbase.security.logger} log4j.additivity.SecurityLogger=true log4j.logger.SecurityLogger.org.apache.hadoop.hbase.security.access.AccessController ``` 以上配置指定了...