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

log4j的additivity和category使用

 
阅读更多

原文出处为: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
  1. dest1会输出INFO以上的消息
  2. 对于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多文件输出打印

    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使用详细说明

    Log4j 是一款广泛使用的日志记录框架,尤其在Java应用程序中非常常见。它提供了灵活的日志配置,允许开发者根据需要调整日志级别、输出格式和目标。在本文中,我们将详细探讨Log4j的配置文件,包括.properties和.xml...

    LOG4J配置全接触

    - `log4j.additivity.org.apache=true`: 此配置表示 org.apache 包下的所有类的日志输出都会按照默认的 rootLogger 的配置进行记录,而不是只按照 org.apache 下的单独配置。 **2. Socket Appender** - 用于通过...

    log4j配置大全-java

    log4j.additivity.org.apache=true ``` 此配置表明对于名为`org.apache`的包下的所有类的日志输出,都将遵循root logger的配置。如果设置为`false`,则该包下的类会使用自己的单独配置。 **3. Console Appender** ...

    Log4j 日志文件Linux/Mac/Windows通用存放位置设置方法

    Log4j 是一个广泛使用的 Java 日志框架,它允许开发者控制和管理应用程序的日志输出。在不同的操作系统如 Linux、Mac 和 Windows 上,设置 Log4j 的日志文件存放位置是非常重要的,因为它可以帮助我们更好地组织和...

    开源框架log4cpp和日志模块实现.pdf

    配置文件(如test_log4cpp2.conf)用于定义Category和Appender的关系,设置日志级别和输出策略。例如,rootCategory设置全局日志级别,而category.sub1等定义子类别及其关联的Appender。 7. **日志回滚与切割**: ...

    Log4j不同模块输出到不同的文件中

    Log4j是一个广泛使用的日志记录框架,它允许开发者对应用程序进行详细的日志记录,以帮助调试、性能分析和故障排查。在某些情况下,我们希望将不同模块的日志信息输出到不同的文件中,以便于管理和分析。以下是实现...

    log4cpp-1.1.2.tar.gz

    Log4cpp是基于Apache的Log4j项目开发的,它遵循了Log4j的设计理念,提供了一个灵活、可扩展的日志框架。这个库的主要目标是使日志记录过程简单而高效,允许开发者根据需要调整日志级别,选择不同的日志输出目的地,...

    HBase开启审计日志

    log4j.category.SecurityLogger=${hbase.security.logger} log4j.additivity.SecurityLogger=true log4j.logger.SecurityLogger.org.apache.hadoop.hbase.security.access.AccessController ``` 以上配置指定了...

Global site tag (gtag.js) - Google Analytics