从log4j appender中排除一个类

dig*_*nie 8 java log4j

我有一个log4j.properties文件,看起来像这样:

log4j.logger.com.foo=INFO, foo-log
log4j.logger.com.foo.BarImpl=INFO, bar-log
Run Code Online (Sandbox Code Playgroud)

通常对于匹配包结构的类,com.foo我希望使用foo-logappender.但是,在该包中,我希望BarImpl日志使用bar-logappender而不是foo-logappender.目前,BarImpl编写的任何日志都由foo-log和bar-log处理(如预期的那样).如何让foo-log appender忽略BarImpl类?

Jas*_*son 14

从Log4j文档:

对于给定记录器,每个启用的日志记录请求都将转发到该记录器中的所有appender以及层次结构中较高的appender.换句话说,appender是从记录器层次结构中附加地继承的.例如,如果将控制台appender添加到根记录器,则所有启用的记录请求将至少在控制台上打印.如果另外将文件追加器添加到记录器(例如C),则对C和C的子节点启用的日志记录请求将在文件和控制台上打印.通过将additivity标志设置为false,可以覆盖此默认行为,以便不再添加appender累积.

尝试尝试以下行(或类似):

log4j.additivity.com.foo.BarImpl = FALSE