java - org - Cómo configurar log4j para registrar diferentes niveles de registro en diferentes archivos para el mismo registrador
org/apache/logging/log4j/logmanager (4)
Lo que necesita hacer es tener una sola definición de <logger>
con un nivel definido de INFO, pero en sus dos definiciones de apéndice, establece sus umbrales en consecuencia, por ejemplo
<appender name="ERROR_FILE">
<param name="Threshold" value="ERROR"/>
</appender>
<appender name="GENERAL">
<param name="Threshold" value="INFO"/>
</appender>
A continuación, agrega los dos apéndices a su registrador:
<logger name="com.acme">
<level value="INFO"/>
<appender-ref ref="ERROR_FILE"/>
<appender-ref ref="GENERAL"/>
</logger>
Las entradas de registro que ahora van al registrador se enviarán a ambos apéndices, pero dado que tienen diferentes umbrales independientes, el apilador ERROR_FILE solo registrará ERROR y más.
Tengo un registro de nivel INFO normal para la aplicación. Lo que necesito es registrar adicionalmente todos los eventos de nivel de ERROR para separar el registro de errores. Estoy usando una configuración como esta:
<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>
Esta configuración solo registra errores. Si pongo el registrador de nivel de información primero, entonces se registrará solo en el apéndice general, pero el registrador de errores no funcionará. Me gustaría que ambos trabajen.
Necesita usar los filtros log4j:
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="levelMin" value="ERROR" />
<param name="levelMax" value="ERROR" />
</filter>
De esta forma, puede crear archivos de registro para cada nivel por separado.
Si está utilizando log4j2 y config con formato XML, ThresholdFilter es una buena solución.
Aquí hay una muestra:
<?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="INFO"/>
</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="ERROR"/>
</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>
Solución de trabajo completa que incluye la fecha en el nombre de archivo:
<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>