Настроить log4net для отправки ошибок в разные приложения на основе уровня
Я хочу отправить Info Level и выше в XML-приложение и Error/Fatal Level в приложение EventLog.
Я понимаю, что мне нужно изменить корневой элемент конфигурации, но я боюсь синтаксиса. Каков синтаксис конфигурации для прямого ведения журналов к правильному приложению для заданного уровня или диапазона уровней?
Это конфигурация до сих пор:
<log4net>
<appender name="SomeXmlAppender" type="log4net.Appender.RollingFileAppender">
...
</appender>
<appender name="SomeEventLogAppender" type="log4net.Appender.EventLogAppender">
...
</appender>
<root>
<level value="DEBUG" />
<appender-ref ref="SomeXmlAppender" />
<appender-ref ref="SomeEventLogAppender" />
</root>
</log4net>
Изменить: Спасибо @agileguy. Этот пост действительно содержит синтакс, который мне нужен. Рабочее решение теперь выглядит следующим образом:
<log4net>
<appender name="SomeXmlAppender" type="log4net.Appender.RollingFileAppender">
...
<evaluator type="log4net.Core.LevelEvaluator">
<threshold value="INFO"/>
</evaluator>
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="INFO" />
<acceptOnMatch value="true" />
</filter>
<filter type="log4net.Filter.DenyAllFilter" />
</appender>
<appender name="SomeEventLogAppender" type="log4net.Appender.EventLogAppender">
...
<evaluator type="log4net.Core.LevelEvaluator">
<threshold value="ERROR"/>
</evaluator>
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="ERROR" />
<acceptOnMatch value="true" />
</filter>
<filter type="log4net.Filter.DenyAllFilter" />
</appender>
<root>
<level value="DEBUG" />
<appender-ref ref="SomeXmlAppender" />
<appender-ref ref="SomeEventLogAppender" />
</root>
</log4net>
Ответы
Ответ 1
Это можно сделать с помощью элементов threshold
или filter
в приложении.
Обратите внимание, что порог может быть непосредственно под приложением, где он действует как включающий фильтр, или под evaluator
например.
<evaluator type="log4net.Core.LevelEvaluator">
<threshold value="ERROR"/>
</evaluator>
где он действует как инклюзивный фильтр для пропуска буферизации (немедленный вывод), где это применимо.
Полное объяснение (источник):
<threshold value="ERROR" />
Порог реализован в AppenderSkeleton
, и поэтому поддерживается почти всеми добавителями. Это просто простой тест, который используется для игнорирования событий регистрации, которые имеют уровень ниже порогового значения. Порог проверяется рано, и как простой тест очень производительным.
Существует еще один способ указать то же поведение, что и порог используя фильтры. Фильтры очень гибкие, и поскольку они вы можете также разработать свою собственную логику и вставить ее в цепочку фильтров.
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="ERROR" />
<levelMax value="OFF" />
</filter>
Как и проверка пороговых значений Фильтры реализованы в базовом классе AppenderSkelton и поддерживаются почти всеми добавителями. Вышеуказанный фильтр имеет тот же эффект, что и <threshold value="ERROR" />
. Это LevelRangeFilter, который позволит через любые события с уровнем в диапазоне от ERROR
до OFF
(включительно). Обратите внимание, что OFF
- это имя самого высокого уровня, обратно ALL
- это имя самого низкого уровня.
Фильтры имеют большую гибкость, поскольку несколько фильтров могут соединяться вместе, чтобы обеспечить мелкозернистый контроль над событиями которые выводятся. Из-за этого они также имеют более высокую стоимость в терминах производительности, каждый фильтр в цепочке является объектом, и ему предлагается принять решение о правильном направлении действий. В простом случае пороговая фильтрация свойства Threshold должна использоваться в предпочтение к фильтру.
evaluator
реализуется BufferingAppenderSkeleton
и поэтому поддерживается только приложением, расширяющим этот базовый класс и обеспечивают поддержку буферизации. SmtpAppender является одним из таких Appender.
evaluator
- это подключаемый объект, который используется BufferingAppenderSkeleton, чтобы определить, не должно ли событие регистрации буферизуется, но вместо этого записывается/отправляется немедленно. Если Оценщик решает, что событие важно, а затем все содержимое текущий буфер будет отправлен вместе с событием. Оценщик делает не работает как порог или фильтр, так как он не отбрасывать события.
Ответ 2
Вы можете установить для каждого appender другое свойство порога. Все события журнала с более низким уровнем, чем пороговый уровень, игнорируются приложением. Я вставляю ниже двух приложений, один для файлов и другой для базы данных (вы должны установить строку подключения). У пользователя базы данных есть свойство порога, указывающее, что в базе данных будут сохраняться только ошибки.
<configuration>
<log4net>
<!--Database appender-->
<appender name="DbAppender" type="log4net.Appender.ADONetAppender">
<bufferSize value="0" />
<connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
<connectionString value="Data Source=AEG-PC\SQLEXPRESS;Initial Catalog=JCZ6;Uid=sa;Pwd=qwerty;" />
<commandText value="INSERT INTO Log4Net ([date],[thread],[level],[logger],[message],[exception]) VALUES
(@log_date, @thread, @log_level, @logger, @message, @exception)" />
<parameter>
<parameterName value="@log_date" />
<dbType value="DateTime" />
<layout type="log4net.Layout.RawTimeStampLayout" />
</parameter>
<parameter>
<parameterName value="@thread" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%t" />
</layout>
</parameter>
<parameter>
<parameterName value="@log_level" />
<dbType value="String" />
<size value="10" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%p" />
</layout>
</parameter>
<parameter>
<parameterName value="@logger" />
<dbType value="String" />
<size value="255" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%c" />
</layout>
</parameter>
<parameter>
<parameterName value="@message" />
<dbType value="String" />
<size value="4000" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%m" />
</layout>
</parameter>
<parameter>
<parameterName value="@exception" />
<dbType value="String" />
<size value="4000" />
<layout type="log4net.Layout.ExceptionLayout" />
</parameter>
<threshold value="Error" /> <!--THIS IS THE IMPORTANT LINE-->
</appender>
<!--File appender-->
<appender name="FileAppender" type="log4net.Appender.FileAppender">
<file value="log-file.txt" />
<appendToFile value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
</layout>
</appender>
<root>
<level value="INFO" />
<appender-ref ref="FileAppender" />
<appender-ref ref="DbAppender" />
</root>
</log4net>
</configuration>
Ответ 3
У меня был тот же вопрос. Похоже, что я понимаю исходный вопрос, что пороговые значения не будут работать, поскольку он отправит определенный результат одному приложению, а это плюс остальные остальные. Мне удалось заставить его работать с использованием LevelRangeFilter, как было предложено выше. Я хотел, чтобы ERROR, INFO и WARN отправились в один appender и все остальные, чтобы перейти к другому приложению, но не ERROR, INFO и WARN.
Здесь конфигурация, которая работала для меня:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<appender name="LoggingAppender" type="log4net.Appender.FileAppender" >
<file value="logs.txt" />
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="INFO"/>
<levelMax value="OFF"/>
</filter>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger [%ndc] - %message%newline" />
</layout>
</appender>
<appender name="TracingAppender" type="log4net.Appender.FileAppender" >
<file value="traces.txt" />
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="ALL"/>
<levelMax value="DEBUG"/>
</filter>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger [%ndc] - %message%newline" />
</layout>
</appender>
<root>
<appender-ref ref="LoggingAppender"/>
<appender-ref ref="TracingAppender"/>
</root>
</log4net>
</configuration>
Спасибо,
Ник