gpt4 book ai didi

java - log4j + log4mongo - 配置不同级别的多个appender

转载 作者:可可西里 更新时间:2023-11-01 09:55:45 36 4
gpt4 key购买 nike

我正在尝试配置 log4j 以将所有内容记录到我的日志文件附加程序中,并将所有错误记录到 mongoDbAppender

如果我将 mongoDbAppender 添加到根记录器,那么它会将所有内容记录到它以及日志文件中。

但是如果我创建一个单独的记录器并为其分配一个错误 级别或任何其他级别,它不会向 mongoDbAppender 记录任何内容。

下面是我的 log4j.xml 的样子:

<?xml version="1.0" encoding="UTF-8"?>

<!-- Appenders -->
<appender name="console" class="org.apache.log4j.ConsoleAppender">
<param name="Target" value="System.out" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%X{application} %X{ua} %5p %d{ISO8601} [%t] %c{1} - %m%n" />
</layout>
</appender>

<appender name="file" class="org.apache.log4j.rolling.RollingFileAppender">
<param name="file" value="/var/www/log/logfile.log"/>
<param name="append" value="true" />
<param name="encoding" value="UTF-8" />
<rollingPolicy class="org.apache.log4j.rolling.TimeBasedRollingPolicy">
<param name="FileNamePattern" value="logfile.%d.log.gz" />
</rollingPolicy>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%X{application} %X{ua} %5p %d{ISO8601} [%t] %c{1} - %m%n" />
</layout>
</appender>

<appender name="mongo" class="org.log4mongo.MongoDbAppender">
<param name="hostname" value="localhost"/>
<param name="port" value="27017"/>
<param name="databaseName" value="test"/>
<param name="collectionName" value="errorBundle"/>
</appender>

<logger name="errorlogger">
<level value="error"/>
<appender-ref ref="mongo" />
</logger>

<!-- Root Logger -->
<root>
<priority value="info" />
<appender-ref ref="console" />
<appender-ref ref="file" />
</root>

我还尝试向 mongodb appender 添加一个过滤器并将其添加到根记录器堆栈,然后它也没有向 mongodb 记录任何内容。

<filter class="org.apache.log4j.filter.LevelRangeFilter">
<param name="LevelMin" value="error"/>
<param name="LevelMax" value="error"/>
</filter>

请帮助我,我做错了什么。我怎样才能只记录 mongodb appender 中的错误。

谢谢你。

最佳答案

我不知道你试过什么,所以尝试这样配置你的appender的错误级别:

<appender name="mongo" class="org.log4mongo.MongoDbAppender">
<param name="hostname" value="localhost"/>
<param name="port" value="27017"/>
<param name="databaseName" value="test"/>
<param name="collectionName" value="errorBundle"/>
<filter class="LoggerFilterLevelRange">
<param name="levelMin" value="error" />
<param name="levelMax" value="error" />
</filter>
</appender>

关于java - log4j + log4mongo - 配置不同级别的多个appender,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24550070/

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