C# Log4Net将两个不同级别的日志记录到同一记录器的两个不同附加器
我们有两个不同的asp.net应用程序启用了Log4net日志记录。 它们都有相同版本的Log4Net,1.2.10.0 我们已将C# Log4Net将两个不同级别的日志记录到同一记录器的两个不同附加器,c#,asp.net,logging,log4net,C#,Asp.net,Logging,Log4net,我们有两个不同的asp.net应用程序启用了Log4net日志记录。 它们都有相同版本的Log4Net,1.2.10.0 我们已将log4net.Appender.AdoNetAppender记录器添加到这两个日志中,并希望为根日志记录器记录信息级别,但也希望为根日志记录器记录错误级别到文件Appender。 我们的配置如下: <?xml version="1.0" encoding="utf-8"?> <log4net> <appender name="
log4net.Appender.AdoNetAppender
记录器添加到这两个日志中,并希望为根日志记录器记录信息级别,但也希望为根日志记录器记录错误级别到文件Appender。
我们的配置如下:
<?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
是我们在两个应用程序的Application\u Start()
中设置的GlobalContext
属性。这两种配置之间的唯一区别是,我们对应用程序
有不同的硬编码值
我们能有两个这样的根记录器吗?这可能是我们在一个应用程序中看到的问题的根源吗?不允许使用两个
元素
发件人:
但是,您可以像以前一样使用根记录器,然后使用命名空间指定的单独记录器
<root>
<level value="Error"/>
<appender-ref ref="filelogAppender"/>
</root>
<logger name="MyCompany.MyApp.Namespace">
<level value="Info"/>
<appender-ref ref="dbLogAppender"/>
</logger>
您应该能够分别设置每个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>
您可以为每个appender指定一个LevelRangeFilter
,并在根目录中定义每个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>
只需使用Evaluator,您不需要在所有附加器中给出阈值
<appender name="filelogAppender" type="log4net.Appender.RollingFileAppender">
<evaluator type="log4net.Core.LevelEvaluator">
<threshold value="ERROR" />
</evaluator>
</appender>
但是,我们希望将root用户记录到两个位置。我们不想限制特定名称空间的日志记录。因此,我们尝试使用两个根记录器。[这在其中一个应用程序上奇怪地起作用]否则,我们需要为每个可能的根命名空间创建大量日志,并将additivity
设置为false。这是一个很好的答案!提供了我完全不知道的灵活性。我想我会使用@barry answer,因为我不需要定义一个范围,只需要定义一个阈值。出于某种原因,“阈值”和“求值器”节点对我不起作用,但确实起了作用(我将levelMin和levelMax指定为相同的值)。我只是遇到了一个问题,即一旦在appender中使用了levelMin,它必须在所有appender中指定,否则在我的例子中过滤不能正常工作,只考虑了根级别。
<appender name="filelogAppender" type="log4net.Appender.RollingFileAppender">
<evaluator type="log4net.Core.LevelEvaluator">
<threshold value="ERROR" />
</evaluator>
</appender>