Полезное для программистов:

Фриланс
Новости
Статьи
   
Рубрики:

Error. Page cannot be displayed. Please contact your service provider for more details. (17)


Как сделать фильтрацию сообщений в Log4j

Поиск:
Часто при использовании Log4j бывает нужно фильтровать сообщения по тому или иному критерию.

Для этих целей в Log4j предусмотрен механизм фильтров. Фильтр это класс унаследованный от org.apache.log4j.spi.Filter. Фильтр устанавливается для конкретного Appender-а, фильтры могу образовывать цепочку. Каждый фильтр получает объект типа LoggingEvent и должен вернуть результат фильтрации:
  • Filter.ACCEPT - сообщение можно писать в лог (следующие в цепочке фильры, не вызываются)
  • Filter.NEUTRAL - сообщение следует передать дальше по цепочке (если фильтр последний, то сообщение пишется в лог)
  • Filter.DENY - сообщение не следует писать в лог (следующие в цепочке фильры, не вызываются)
Если надо написать свой фильтр, то надо унаследовать его от базового класса и переопределить метод public int decide(LoggingEvent).

В состав библиотеки Log4j уже входит несколько стандартных фильтров, в частности есть фильты для фильтрации сообщений по уровню:
  • LevelMatchFilter - пишутся только сообщения указанного уровня
  • LevelRangeFilter - пишутся только сообщения с уровнем попадающим в указанный диапазон
Рассмотрим на как организовать вывод в консоль только отладочных (DEBUG) сообщений:
Код
LevelMatchFilter matchFilter = new LevelMatchFilter();
matchFilter.setLevelToMatch("DEBUG");
ConsoleAppender errAppender = new ConsoleAppender(new PatternLayout("%d{dd-MM-yyyy HH:mm:ss.SSS} | %-5p | %m%n"), "System.err");
errAppender.addFilter(matchFilter);


Еще один пример как организовать вывод отладочной информации в отдельный файл, с помощью конфигурационного файла:
Код
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration>

  <appender name="Console" class="org.apache.log4j.ConsoleAppender">
    <param name="Target" value="System.out"/> 
    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="%-5p: %m%n"/>
    </layout>
  </appender>

  <appender name="File" class="org.apache.log4j.FileAppender">
    <param name="File" value="main.log"/>
    <param name="Append" value="false"/>
    <param name="BufferedIO" value="false"/>
    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="%d [%-5p] %m {at %c}%n"/>
    </layout>
    <filter class="org.apache.log4j.varia.LevelRangeFilter">
      <param name="LevelMax" value="OFF"/>
      <param name="LevelMin" value="INFO"/>
    </filter>
  </appender>

  <appender name="DebugFile" class="org.apache.log4j.FileAppender">
    <param name="File" value="debug.log"/>
    <param name="Append" value="false"/>
    <param name="BufferedIO" value="false"/>
    <layout class="org.apache.log4j.PatternLayout">
      <param name="ConversionPattern" value="%d [%-5p] %m {at %c}%n"/>
    </layout>
    <filter class="org.apache.log4j.varia.LevelRangeFilter">
      <param name="LevelMax" value="DEBUG"/>
      <param name="LevelMin" value="ALL"/>
    </filter>
  </appender>

  <root>
    <priority value ="ALL"/>
    <appender-ref ref="Console"/>
    <appender-ref ref="File"/>
    <appender-ref ref="DebugFile"/>
  </root>

</log4j:configuration>


Создадим свой Filter, который будет фильтровать сообщения на основе регулярных выражений:
Код
public class RegexFilter extends Filter
{
  private Pattern pattern;

  public RegexFilter()
  {
  }

  public String getPattern()
  {
    return pattern == null ? null : pattern.pattern();
  }

  public void setPattern(String pattern)
  {
    try
    {
      this.pattern = Pattern.compile(pattern);
    }
    catch(PatternSyntaxException ex)
    {
      this.pattern = null;
      throw ex;
    }
  }

  public int decide(LoggingEvent event)
  {
    if(pattern == null)
      return Filter.NEUTRAL;

    if(pattern.matcher(event.getMessage().toString()).matches())
      return Filter.ACCEPT;
    else
      return Filter.DENY;
  }
}
Автор: LSD






Просмотров: 3053

 

 

Новые статьи:


Популярные:
  1. Как сделать цикличным проигрывание MIDI-файла?
  2. Создание AVI файла из рисунков
  3. Как устройство "отключить в данной конфигурации"?
  4. Kто в данный момент присоединен через Сеть?
  5. Как узнать количество доступной памяти?
  6. Как реализовать в RichEdit разноцветный текст?
  7. Как скрыть свое приложение от ProcessViewer
  8. Как программно нажать/скрыть/показ кнопку "Start"?
  9. Модуль работы с ресурсами в PE файлах
10. Функции вызова диалоговых окон выбора
11. Проверка граматики средствами Word'а из Delphi.
12. Модуль для упрощенного вызова сообщений
13. Функции для записи и чтение своих данных в, ЕХЕ- файле
14. Рекурсивный просмотр директорий
15. Network Traffic Monitor
16. Разные модули
17. Универсальная функция для обращения к любым экспортируем функциям DLL
18. Библиотека от VladS
19. Протектор для UPX'а
20. Еще об ICQ, сообщения по контакт листу?
21. Использование открытых интерфейсов
22. Теория и практика использования RTTI
23. Работа с TApplication
24. Примеры использования Drag and Drop для различных визуальных компонентов
25. Что такое порт? Правила для работы с портами
26. Симфония на клавиатуре
27. Загрузка DLL
28. Исправление автоинкремента
29. Взаимодействие с чужими окнами
30. Проверить дубляжи в столбце


 

 

 
 
На главную