2014-01-17 2 views
50

У нас есть два разных приложения asp.net с включенным протоколированием Log4net. Оба они имеют ту же версию Log4Net, 1.2.10.0.Log4Net Регистрация двух разных уровней для двух разных приложений для одного и того же журнала

Мы добавили регистратор log4net.Appender.AdoNetAppender к ним обоим и хотим зарегистрировать информационный уровень для него для корневого регистратора, но также хотим войти на уровень ошибки для корневого регистратора в файл-приложение. Наша конфигурация такова:

<?xml version="1.0" encoding="utf-8"?> 

<log4net> 
    <appender name="filelogAppender" type="log4net.Appender.RollingFileAppender" > 
     <file value="..\logs\app.debug.log" /> 
     <encoding value="utf-8" /> 
     <staticLogFileName value="true" /> 
     <datePattern value=".yyyyMMdd.'log'" /> 
     <rollingStyle value="Composite" /> 
     <lockingModel type="log4net.Appender.FileAppender+MinimalLock" /> 
     <appendToFile value="true" /> 
     <maximumFileSize value="1MB" /> 
     <layout type="log4net.Layout.PatternLayout"> 
      <conversionPattern value="%date [%3thread] %-5level %property{log4net:HostName} [%property{Revision}] %logger %message%n" /> 
     </layout> 
    </appender> 
    <!--  
     use [DB] 
     GO 
     CREATE TABLE [dbo].[Log] (
      [Id] [int] IDENTITY (1, 1) NOT NULL, 
      [Date] [datetime] NOT NULL, 
      [Application][varchar] (255) NOT NULL, 
      [Thread] [varchar] (255) NOT NULL, 
      [Level] [varchar] (50) NOT NULL, 
      [Logger] [varchar] (255) NOT NULL, 
      [Server][varchar](255) NOT NULL, 
      [Revision][varchar](50) NOT NULL, 
      [Message] [varchar] (4000) NOT NULL, 
      [Exception] [varchar] (2000) NULL 
     ) 
    --> 
    <appender name="dbLogAppender" type="log4net.Appender.AdoNetAppender" xdt:Transform="InsertBefore(/log4net/root)"> 
     <bufferSize value="100" /> 
     <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" /> 
     <connectionString value="data source=sqlserver;initial catalog=DB;integrated security=false;persist security info=True;User ID=USER;Password=PASSWORD" /> 
     <commandText value="INSERT INTO Log ([Date],[Application],[Thread],[Level],[Logger],[Server],[Revision],[Message],[Exception]) VALUES (@log_date,'WebApp1', @thread, @log_level, @logger, @server, @revision, @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="%thread" /> 
      </layout> 
     </parameter> 
     <parameter> 
      <parameterName value="@log_level" /> 
      <dbType value="String" /> 
      <size value="50" /> 
      <layout type="log4net.Layout.PatternLayout"> 
       <conversionPattern value="%level" /> 
      </layout> 
     </parameter> 
     <parameter> 
      <parameterName value="@logger" /> 
      <dbType value="String" /> 
      <size value="255" /> 
      <layout type="log4net.Layout.PatternLayout"> 
       <conversionPattern value="%logger" /> 
      </layout> 
     </parameter> 
     <parameter> 
      <parameterName value="@server" /> 
      <dbType value="String" /> 
      <size value="255" /> 
      <layout type="log4net.Layout.PatternLayout"> 
       <conversionPattern value="%property{log4net:HostName}"/> 
      </layout> 
     </parameter> 
     <parameter> 
      <parameterName value="@revision" /> 
      <dbType value="String" /> 
      <size value="50" /> 
      <layout type="log4net.Layout.PatternLayout"> 
       <conversionPattern value="%property{Revision}"/> 
      </layout> 
     </parameter> 
     <parameter> 
      <parameterName value="@message" /> 
      <dbType value="String" /> 
      <size value="4000" /> 
      <layout type="log4net.Layout.PatternLayout"> 
       <conversionPattern value="%message" /> 
      </layout> 
     </parameter> 
     <parameter> 
      <parameterName value="@exception" /> 
      <dbType value="String" /> 
      <size value="2000" /> 
      <layout type="log4net.Layout.ExceptionLayout" /> 
     </parameter> 
    </appender> 
    <root> 
     <level value="Error"/> 
     <appender-ref ref="filelogAppender"/> 
    </root> 
    <root> 
     <level value="Info"/> 
     <appender-ref ref="dbLogAppender"/> 
    </root> 
</log4net> 

Вопрос, который мы видим, что для одного приложения, мы видим, записи в БД, но для другого у нас нет.

Revision is GlobalContext Недвижимость, которую мы установили в Application_Start() в обоих случаях. И единственное различие между двумя конфигурациями состоит в том, что у нас есть другое твердое значение для Application.

Возможно, у нас есть два корневых регистратора? Может ли это быть источником нашей проблемы, которую мы видим в одном приложении?

ответ

81

Вы должны быть в состоянии установить threshold свойство каждого Appender отдельно и включить их в тот же корень.

<appender name="filelogAppender" type="log4net.Appender.RollingFileAppender"> 
    <threshold value="Error" /> 
</appender> 
<appender name="dblogAppender" type="log4net.Appender.AdoNetAppender"> 
    <threshold value="Info" /> 
</appender> 
<root> 
    <appender-ref ref="filelogAppender" /> 
    <appender-ref ref="dblogAppender" /> 
</root> 

reference

1

Два элемента <root> не допускаются.

От documentation:

root  Optional element, maximum of one allowed. Defines the configuration of the root logger. 

Однако вы можете иметь корневой регистратор, как вы это делаете, а затем отдельный регистратор, заданный в пространстве имен.

<root> 
    <level value="Error"/> 
    <appender-ref ref="filelogAppender"/> 
</root> 
<logger name="MyCompany.MyApp.Namespace"> 
    <level value="Info"/> 
    <appender-ref ref="dbLogAppender"/> 
</logger> 
+1

Однако мы ** хотим ** зарегистрировать корень в двух местах. Мы не хотим ограничивать запись определенного пространства имен. Отсюда наша попытка использования двух корневых регистраторов. [Что странно работает в одном из приложений] В противном случае нам понадобится создать тонну журналов для каждого возможного корневого пространства имен с параметром 'additivity' равным false. – graney

30

Вы можете указать LevelRangeFilter для каждого из appenders, и определить каждый Appender в корне, чтобы войти на разных уровнях.

<appender name="filelogAppender" type="log4net.Appender.RollingFileAppender" > 
    <!--File Details/Layout Options--> 
    <filter type="log4net.Filter.LevelRangeFilter"> 
     <levelMin value="INFO"/> 
    </filter> 
</appender> 
<appender name="dbLogAppender" type="log4net.Appender.AdoNetAppender"> 
    <!--SQL Options-->  
    <filter type="log4net.Filter.LevelRangeFilter"> 
     <levelMin value="ERROR"/> 
    </filter> 
</appender> 
<root> 
    <level value="INFO"/> 
    <appender-ref ref="filelogAppender" /> <!--Prints info, warn, error, or fatal logs. --> 
    <appender-ref ref="dbLogAppender" /> <!--Prints only error or fatal logs. --> 
</root> 
+1

Отличный ответ! И обеспечивает гибкость, о которой я совершенно не подозревал. Я думаю, что буду использовать ответ @barry, хотя мне не нужно определять диапазон только пороговым значением. – graney

+0

По какой-то причине узлы «порог» и «оценщик» не работали для меня, но это было (я задал levelMin и levelMax как одно и то же значение). – Anssssss

0

Просто используйте Evaluator, вам не нужно указывать пороговое значение во всех добавках.

<appender name="filelogAppender" type="log4net.Appender.RollingFileAppender"> 
     <evaluator type="log4net.Core.LevelEvaluator"> 
      <threshold value="ERROR" /> 
    </evaluator> 
</appender> 
Смежные вопросы