Log4net ведение журнала двух разных уровней для двух разных приложений для одного и того же регистратора
у нас есть два разных asp.net приложения с включенным журналированием Log4net. Они оба имеют одинаковую версию Log4Net, 1.2.10.0.
добавляем log4net.Appender.AdoNetAppender
logger для обоих из них и хотите войти в уровень информации для него для корневого регистратора, но также хотите войти в уровень ошибок для корневого регистратора для приложения файла.
Наша конфигурация выглядит следующим образом;
<?xml version="1.0" encoding="utf-8"?>
<log4net>
<appender name="filelogAppender" type="log4net.Appender.RollingFileAppender" >
<file value="..logsapp.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
.
можем ли мы иметь два корневых регистратора, как это? Может ли это быть источником нашей проблемы, которую мы видим в одном приложении?
4 ответа:
вы должны быть в состоянии установить
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>
вы можете указать
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>
два
<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>