从log4j appender中排除一个类
我有一个log4j.properties文件,看起来像这样:
log4j.logger.com.foo=INFO, foo-log log4j.logger.com.foo.BarImpl=INFO, bar-log
通常对于与com.foo
的包结构匹配的类,我希望使用foo-log
appender。 但是,在该包中,我希望BarImpl
日志使用bar-log
appender而不是foo-log
appender。 目前,BarImpl编写的任何日志都由foo-log和bar-log处理(如预期的那样)。 如何让foo-log appender忽略BarImpl类?
从Log4j文档:
给定记录器的每个启用的日志记录请求都将转发到该记录器中的所有appender以及层次结构中较高的appender。 换句话说,appender是从记录器层次结构中附加地inheritance的。 例如,如果将控制台appender添加到根记录器,则所有启用的日志记录请求将至少在控制台上打印。 如果另外将文件追加器添加到记录器(例如C),则对C和C的子项启用的记录请求将在文件和控制台上打印。 通过将additivity标志设置为false,可以覆盖此默认行为,以便不再添加appender累积。
尝试尝试以下行(或类似):
log4j.additivity.com.foo.BarImpl = FALSE