Log4Net Запис двох різних рівнів у два різні додатки для одного і того ж реєстратора


77

У нас є дві різні програми asp.net із увімкненим журналом Log4net. Обидва вони мають однакову версію Log4Net, 1.2.10.0.

Ми додали 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це GlobalContextвластивість, яку ми встановлюємо Application_Start()в обох додатках. І єдина різниця між цими двома конфігураціями полягає в тому, що ми маємо різне твердокодоване значення для Application.

Чи можемо ми мати два таких кореневих реєстратори? Чи може це бути джерелом нашого випуску, який ми бачимо в одній програмі?

Відповіді:


123

Ви повинні мати можливість встановлювати thresholdвластивості кожного додатка окремо та включати їх в один кореневий каталог.

<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>

посилання


38

Ви можете вказати a LevelRangeFilterдля кожного з додатків та визначити кожного додавача в кореневій системі для реєстрації на різних рівнях.

<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

З якоїсь причини вузли "поріг" та "оцінювач" для мене не працювали, але це так (я вказав levelMin та levelMax як одне і те ж значення).
Anssssss

Я просто мав проблеми з тим, що як тільки levelMin використовується в додатку, він повинен бути вказаний у всіх додатках, інакше фільтрація не працювала належним чином у моєму випадку, і враховувався лише рівень кореневої системи.
Хонза П.

1

Два <root>елементи заборонені.

З документації :

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
Однак ми хочемо зареєструвати root у два місця. Ми не хочемо обмежувати протоколювання конкретного простору імен. Звідси наша спроба використовувати два кореневі реєстратори. [Що дивно працює в одному з додатків] В іншому випадку нам потрібно буде створити тонну реєстраторів для кожного можливого кореневого простору імен, для якого additivityвстановлено значення false.
graney

0

Просто використовуйте Evaluator, вам не потрібно вказувати поріг у всіх додатках.

<appender name="filelogAppender" type="log4net.Appender.RollingFileAppender">
        <evaluator type="log4net.Core.LevelEvaluator">
          <threshold value="ERROR" />
  </evaluator>
</appender>
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.