我有一个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