log4j + log4mongo - 配置多个不同级别的附加器

3
我正在尝试配置log4j将所有内容记录到我的日志文件appender,并将所有错误记录到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中的错误日志。
谢谢您。

尝试使用大写的"ERROR"值。 - Sandstorm
不要看我的上一条评论,我没有仔细阅读,所以请查看http://logging.apache.org/log4php/docs/appenders/mongodb.html,您还没有设置参数密码和用户名,对于错误过滤器,请使用文档中的示例http://logging.apache.org/log4php/docs/filters.html。 - Sandstorm
谢谢您的回复@iFrey,但是如果我的mongodb没有启用身份验证,我不需要用户名和密码参数。您提到的筛选器示例适用于PHP,而我正在使用Java实现,无论如何,我已经以相同的方式实现了它。如果我漏掉了什么,请指出。谢谢。 - Panshul
我会将此作为答案放置,因为代码在评论中看起来很糟糕。 - Sandstorm
1个回答

0

我不知道你尝试过什么,所以试着这样配置你的 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>

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