gpt4 book ai didi

java - Log4j:分包的不同日志级别

转载 作者:行者123 更新时间:2023-11-30 09:04:28 24 4
gpt4 key购买 nike

假设我有以下 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

因此,我想将不是来 self 的应用程序的消息记录到控制台,这些消息是我在自己的日志中创建的,并且对我的子包的消息具有不同的级别。

当我这样尝试时,我会收到两次关于我的子包的消息,即使可加性设置为 false。

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

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

最佳答案

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

# 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 将从其父级 com.company.app 继承 file appender,但继承将在此处停止由于可加性设置,因此它不会从根记录器继承 stdout appender。

关于java - Log4j:分包的不同日志级别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25203821/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com