Как настроить log4j для регистрации различных уровней журнала для разных файлов для одного и того же регистратора
У меня есть нормальный журнал уровня INFO для приложения. Мне нужно дополнительно регистрировать все события уровня ERROR для разделения журнала ошибок. Я использую конфигурацию следующим образом:
<logger name="com.acme">
<level value="error"/>
<appender-ref ref="error"/>
</logger>
<logger name="com.acme">
<level value="info"/>
</logger>
<root>
<level value="warn"/>
<appender-ref ref="general"/>
</root>
В этой конфигурации регистрируются только ошибки. Если я сначала поставлю регистратор уровня информации, тогда он будет регистрироваться только в общем приложении, но журнал ошибок не будет работать. Я хотел бы, чтобы они оба работали.
Ответы
Ответ 1
Что вам нужно сделать, это иметь одно определение <logger>
с определенным уровнем INFO, но в двух ваших определениях appender вы задаете свои пороговые значения соответственно, например.
<appender name="ERROR_FILE">
<param name="Threshold" value="ERROR"/>
</appender>
<appender name="GENERAL">
<param name="Threshold" value="INFO"/>
</appender>
Затем вы добавляете оба регистратора в журнал:
<logger name="com.acme">
<level value="INFO"/>
<appender-ref ref="ERROR_FILE"/>
<appender-ref ref="GENERAL"/>
</logger>
Записи журнала, которые теперь отправляются в журнал, будут отправляться обоим приложениям, но поскольку они имеют разные независимые пороги, приложение ERROR_FILE будет регистрировать только ERROR и выше.
Ответ 2
Полное рабочее решение, включая дату в имени файла:
<appender name="InfoFileAppender" class="org.apache.log4j.rolling.RollingFileAppender">
<rollingPolicy class="org.apache.log4j.rolling.TimeBasedRollingPolicy">
<param name="FileNamePattern" value="/var/output/Info_%d{ddMMyyyy}.log" />
</rollingPolicy>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{HH:mm:ss} %-5p %t %c{2} - %m%n" />
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="levelMin" value="INFO" />
<param name="levelMax" value="INFO" />
</filter>
</appender>
<appender name="ErrorFileAppender" class="org.apache.log4j.rolling.RollingFileAppender">
<param name="Threshold" value="ERROR" />
<rollingPolicy class="org.apache.log4j.rolling.TimeBasedRollingPolicy">
<param name="FileNamePattern" value="/var/output/Error_%d{ddMMyyyy}.log" />
</rollingPolicy>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%d{HH:mm:ss} %-5p %t %c{2} - %m%n" />
</layout>
</appender>
<root>
<level value="INFO" />
<appender-ref ref="InfoFileAppender" />
<appender-ref ref="ErrorFileAppender" />
</root>
Ответ 3
Вам нужно использовать фильтры log4j:
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="levelMin" value="ERROR" />
<param name="levelMax" value="ERROR" />
</filter>
Таким образом, вы можете создавать файлы журналов для каждого уровня отдельно.
Ответ 4
Если вы используете log4j2 и конфигурируете в формате XML, ThresholdFilter является хорошим решением.
Вот пример:
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN">
<Appenders>
<Console name="Console" target="SYSTEM_OUT">
<PatternLayout>
<Pattern>%d %-5p %m%n</Pattern>
</PatternLayout>
<ThresholdFilter level="DEBUG"/>
</Console>
<RollingFile name="RollingDebugLogFile" fileName="logs/app-debug.log" filePattern="logs/$${date:yyyy-MM}/app-debug-%d{MM-dd-yyyy}-%i.log.gz">
<PatternLayout>
<Pattern>%d %-5p %m%n</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy />
<SizeBasedTriggeringPolicy size="20MB"/>
</Policies>
<ThresholdFilter level="DEBUG"/>
</RollingFile>
<RollingFile name="RollingErrorLogFile" fileName="logs/app-info.log" filePattern="logs/$${date:yyyy-MM}/app-info-%d{MM-dd-yyyy}-%i.log.gz">
<PatternLayout>
<Pattern>%d %-5p %m%n</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy />
<SizeBasedTriggeringPolicy size="20MB"/>
</Policies>
<ThresholdFilter level="ERROR"/>
</RollingFile>
<RollingFile name="RollingInfoLogFile" fileName="logs/app-error.log" filePattern="logs/$${date:yyyy-MM}/app-error-%d{MM-dd-yyyy}-%i.log.gz">
<PatternLayout>
<Pattern>%d %-5p %m%n</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy />
<SizeBasedTriggeringPolicy size="20MB"/>
</Policies>
<ThresholdFilter level="INFO"/>
</RollingFile>
</Appenders>
<Loggers>
<Logger name="testLogger" level="DEBUG" additivity="false">
<AppenderRef ref = "Console" />
<AppenderRef ref="RollingErrorLogFile" />
<AppenderRef ref="RollingInfoLogFile" />
<AppenderRef ref="RollingDebugLogFile" />
</Logger>
<Root level="INFO">
<AppenderRef ref = "Console" />
<AppenderRef ref="RollingErrorLogFile" />
<AppenderRef ref="RollingInfoLogFile" />
<AppenderRef ref="RollingDebugLogFile" />
</Root>
</Loggers>
</Configuration>