I am trying to configure log4j to log everything into my log file appender and all the errors to mongoDbAppender .
If I add the mongoDbAppender to the root logger, then it logs everything to it as well as to the log file.
But if I create a separate logger and assign it a error level or any other level, it does not log anything to the mongoDbAppender.
Following is how my log4j.xml looks:
<?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>
I also tried to add a filter to the mongodb appender and added it to the root logger stack, then also it did not log anything to mongodb.
<filter class="org.apache.log4j.filter.LevelRangeFilter">
<param name="LevelMin" value="error"/>
<param name="LevelMax" value="error"/>
</filter>
Please help me, what I am doing wrong. How can I log only the errors in mongodb appender.
Thanking You.
I don't know what have you tried, so try to configure the error level of your appender this way:
<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>
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.