我知道在log4j中你可以通过做类似的事情来使用多个appender:
log4j.logger.com.x=DEBUG, append1, append2
但log4j2中的等价性是什么?
会是这样的:
logger.com.x.level = DEBUG
logger.com.x.appenderRefs = append1, append2
答案 0 :(得分:6)
您没有在示例中提供apundder append1和append2的类型,但这在您使用属性文件时很重要。假设appender定义如下:
appender.console.type = Console
appender.console.name = append1
...
appender.rolling.type = RollingFile
appender.rolling.name = append2
...
记录器应该是这样的:
logger.console.name = com.x
logger.console.level = debug
logger.console.additivity = false
logger.console.appenderRef.console.ref = append1
logger.rolling.name = com.x
logger.rolling.level = debug
logger.rolling.additivity = false
logger.rolling.appenderRef.rolling.ref = append2
我建议根据manual中的属性文件配置示例进行此配置。我不是这样做的,而是更喜欢xml格式。我建议你考虑转向xml格式。 log4j2文档中的大多数示例都是针对xml配置格式的。 对于xml,记录器配置非常紧凑,就像这样:
<Loggers>
<Logger name="com.x" level="debug" additivity="false">
<appenderRef ref="append1" />
<appenderRef ref="append2" />
</Logger>
...
</Loggers>
答案 1 :(得分:3)
我知道这是一个相当古老的问题,但我通过使用以下语法找到了解决方案(使用您的示例):
logger.com.x.appenderRef.app1.ref = append1
logger.com.x.appenderRef.app2.ref = append2
通过这种方式,一切正常。