簡體   English   中英

log4j + log4mongo - 配置具有不同級別的多個appender

[英]log4j + log4mongo - Configure multiple appenders with different levels

我正在嘗試配置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中的錯誤。

感謝您。

我不知道你嘗試了什么,所以嘗試以這種方式配置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>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM