Log4j:子包的不同日志级别

时间:2014-08-08 12:42:31

标签: java logging log4j

我们说我有以下log4j.properties:

# Root logger option
log4j.rootLogger=INFO, stdout
# Direct normal log messages to stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS} %-5p %c{1}:%L - %m%n

# Application logs
log4j.logger.com.company.app=DEBUG, file
log4j.additivity.com.company.app=false
log4j.logger.com.company.app.sub=TRACE, file
log4j.additivity.com.company.app.sub=false

# Direct application log messages to a custom log file
log4j.appender.file=org.apache.log4j.DailyRollingFileAppender
log4j.appender.file.File=${com.sun.aas.instanceRoot}/logs/app.log
log4j.appender.file.DatePattern='.'yyyy-MM-dd-a
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss.SSS} %-5p %c{1}:%L - %m%n

因此,我想将不应该来自我的应用的消息记录到控制台,我在自己的日志中创建的消息以及我的子包的消息具有不同的级别。

当我这样尝试时,即使将additivity设置为false,我也会为子包发送两次消息。

我想要实现的是将我应用程序中的所有消息记录一次(不是主日志,而是记录到我自己的文件中),但是能够为子包设置不同的级别。

我使用log4j v 1.2和SLF4J作为前端。

1 个答案:

答案 0 :(得分:2)

您不需要将file appender附加两次,只需在com.company.app级别附加一次,并让可加性做正确的事情:

# Application logs
log4j.logger.com.company.app=DEBUG, file
log4j.additivity.com.company.app=false
log4j.logger.com.company.app.sub=TRACE

此处com.company.app.sub将从其父file继承com.company.app appender,但由于可加性设置,继承将停在此处,因此它不会继承stdout来自根记录器的appender。