log4j:将特定类的日志输出到特定appender

175

我使用log4j,并希望将某些Loggers的输出路由到特定的文件。

我已经有多个appenders了。现在为了方便调试,我想告诉log4j,由特定类(例如foo.bar.Baz)生成的输出应写入特定的日志文件。

这可以实现吗?

3个回答

214
一个例子:
log4j.rootLogger=ERROR, logfile

log4j.appender.logfile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.logfile.datePattern='-'dd'.log'
log4j.appender.logfile.File=log/radius-prod.log
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%-6r %d{ISO8601} %-5p %40.40c %x - %m\n

log4j.logger.foo.bar.Baz=DEBUG, myappender
log4j.additivity.foo.bar.Baz=false

log4j.appender.myappender=org.apache.log4j.DailyRollingFileAppender
log4j.appender.myappender.datePattern='-'dd'.log'
log4j.appender.myappender.File=log/access-ext-dmz-prod.log
log4j.appender.myappender.layout=org.apache.log4j.PatternLayout
log4j.appender.myappender.layout.ConversionPattern=%-6r %d{ISO8601} %-5p %40.40c %x - %m\n

22
啊 - 真简单!谢谢!log4j.additivity.foo.bar.Baz=false 这个设置是否强制 Baz 的输出不会出现在 rootLogger 的 appender 中? - gubrutz
3
这是针对哪个版本的log4J?我正在尝试寻找用于log4j版本1.2.17的XML配置,希望你可以帮忙翻译。 - A.C
1
@RodrigoGurgel 是的,那里没有什么不寻常的。 - Maurice Perry
5
将 additivity 设置为 false 将防止记录器将日志记录到其祖先的附加程序中(默认情况下为 true)。在这种情况下,如果 additivity 保持为 true,则写入 Baz 附加程序的日志将写入两个文件。 - Maurice Perry
2
看到我的回答下面的XML配置,我今天正在寻找它... - mikeb
显示剩余6条评论

22

这是关于XML配置的答案,请注意,如果您不给文件 appender 提供 ConversionPattern,它将创建一个0字节的文件并不会写入任何内容:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
    <appender name="console" class="org.apache.log4j.ConsoleAppender">
        <param name="Target" value="System.out"/>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-5p %c{1} - %m%n"/>
        </layout>
    </appender>

    <appender name="bdfile" class="org.apache.log4j.RollingFileAppender">
        <param name="append" value="false"/>
        <param name="maxFileSize" value="1GB"/>
        <param name="maxBackupIndex" value="2"/>
        <param name="file" value="/tmp/bd.log"/>
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-5p %c{1} - %m%n"/>
        </layout>
    </appender>

    <logger name="com.example.mypackage" additivity="false">
        <level value="debug"/>
        <appender-ref ref="bdfile"/>
    </logger>

    <root>
        <priority value="info"/>
        <appender-ref ref="bdfile"/>
        <appender-ref ref="console"/>
    </root>

</log4j:configuration>

4
<root> 中删除 <appender-ref ref="bdfile"/> 是至关重要的 - 否则你将看到整个日志也被复制到这个文件中。 - sab
如何配置默认包或特定类而不使用包? - Prasad Jadhav
这是<logger>...元素。将类或包指定为名称,将appender指定为文件appender。 - mikeb

1
这里有一个将详细信息记录到单独文件的示例,每个月滚动文件并删除早于180天的日志:
#property settings
property.LOG_DIR = /opt/logs/app_name/

#Console appenders
appender.console.type = Console
appender.console.name = STDOUT
appender.console.layout.type = PatternLayout
appender.console.layout.pattern = %d{yy/MM/dd HH:mm:ss.SSS} %p %c{1}: %m%n

#root loggers
rootLogger.level = INFO
rootLogger.appenderRef.stdout.ref = STDOUT
rootLogger.appenderRefs = stdout
rootLogger.appenderRef.files.ref = Rolling

# Rolling file appender
appender.rolling.type = RollingFile
appender.rolling.name = Rolling
appender.rolling.fileName= ${LOG_DIR}/application.log
appender.rolling.filePattern= ${logFile}.%i
appender.rolling.layout.type=PatternLayout
appender.rolling.layout.pattern=%d{yy/MM/dd HH:mm:ss.SSS} %p %c{1}: %m%n
appender.rolling.policies.type=Policies
appender.rolling.policies.size.type = SizeBasedTriggeringPolicy
appender.rolling.strategy.type = DefaultRolloverStrategy
appender.rolling.policies.size.size=50MB
appender.rolling.strategy.max=20

#custom logging for audit-viewer
logger.aduit.name = auditlogger
logger.aduit.level = info
logger.aduit.appenderRefs = auditRef
logger.aduit.appenderRef.auditRef.ref = AuditAppender
logger.aduit.additivity = false

# Logging audit details to dedicated file
appender.aduitfile.type = RollingFile
appender.aduitfile.fileName = ${AUDIT_FILE}
appender.aduitfile.filePattern= ${LOG_DIR}/audit.%d{yyyy-MM}.log
appender.aduitfile.name = AuditAppender
appender.aduitfile.layout.type = PatternLayout
appender.aduitfile.layout.pattern = %d{yy/MM/dd HH:mm:ss.SSS} %p %c{1}: %m%n
appender.aduitfile.policies.type = Policies
appender.aduitfile.policies.time.type =TimeBasedTriggeringPolicy
appender.aduitfile.strategy.type = DefaultRolloverStrategy
#Rollout files based on month
appender.aduitfile.policies.time.interval=1
appender.aduitfile.policies.time.modulate= true
appender.aduitfile.ImmediateFlush=true
appender.aduitfile.append=true
appender.aduitfile.strategy.action.type = Delete
appender.aduitfile.strategy.action.basepath = ${LOG_DIR}
appender.aduitfile.strategy.action.maxdepth = 1
appender.aduitfile.strategy.action.PathConditions.type = IfFileName
#This below field uses relative path from basepath
appender.aduitfile.strategy.action.PathConditions.glob = audit.*.log
appender.aduitfile.strategy.action.condition.type = IfLastModified
appender.aduitfile.strategy.action.condition.age = P180D


# Settings to quiet third party or custom logs that are too verbose
loggers = mongodb, aduit

logger.mongodb.name=org.mongodb.driver.cluster
logger.mongodb.level=ERROR

如果你希望将某个类的日志记录到单独的文件中,比如auditlogger,那么可以在该类中使用以下代码:

  private val logger = LogManager.getLogger("auditlogger") //dont change this appender ref
  logger.info("Find me inside 'audit.log' file")

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接