我想发送Info Level&以上是对于EventLog appender的XML appender和Error / Fatal Level。
我认为我需要修改配置的根元素,但我正在努力学习语法。对于给定级别或范围的级别,将日志定向到正确的appender的配置语法是什么?
这是迄今为止的配置:
<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>
答案 0 :(得分:14)
可以使用appender中的threshold
或filter
元素来完成此操作。
请注意,阈值可以直接位于appender下,也可以作为包容性过滤器使用,或者在evaluator
下使用。
<evaluator type="log4net.Core.LevelEvaluator">
<threshold value="ERROR"/>
</evaluator>
在适用的情况下,它作为跳过缓冲(即时输出)的包容性过滤器。
完整解释(source):
<threshold value="ERROR" />
阈值在
AppenderSkeleton
中实现,因此 几乎所有的appender支持。这只是一个简单的测试 用于忽略级别低于阈值的日志记录事件。 早期检查阈值,并且非常简单 高性能的。还有另一种方法可以指定与阈值相同的行为 使用过滤器。过滤器非常灵活,就像它们一样 可插拔您也可以开发自己的自定义逻辑并插入它 进入过滤链。
<filter type="log4net.Filter.LevelRangeFilter">
<levelMin value="ERROR" />
<levelMax value="OFF" />
</filter>
与阈值检查类似,过滤器在AppenderSkelton基类中实现,几乎所有appender都支持。上述过滤器与<threshold value="ERROR" />
具有相同的效果。它是一个LevelRangeFilter,允许任何级别在ERROR
到OFF
(包括)范围内的事件。请注意,OFF
是最高级别的名称,相反,ALL
是最低级别的名称。
过滤器具有很大的灵活性,因为多个过滤器可以 被捆绑在一起,为事件提供细致的控制 这是输出。因此,它们的成本也较高 对于性能,链中的每个过滤器都是一个对象并被要求 决定正确的行动方案。在简单的情况下 阈值过滤应该使用阈值属性 偏好过滤器。
Evaluator
由BufferingAppenderSkeleton
实现 因此只有扩展此基类的appender才支持 并提供缓冲支持。 SmtpAppender就是其中之一 附加器。
Evaluator
是一个可插入的对象,由...使用 BufferingAppenderSkeleton确定是否不应该记录日志事件 被缓冲,但是立即写入/发送。如果是评估员 决定事件是重要的,然后是整个内容 当前缓冲区将与事件一起发送。评估员做了 不像阈值或过滤器那样起作用 丢弃事件。
答案 1 :(得分:6)
您可以为每个appender设置不同的阈值属性。 appender会忽略级别低于阈值级别的所有日志事件。我粘贴在两个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>
答案 2 :(得分:2)
我有同样的问题。假设我理解了原始问题,似乎阈值不会起作用,因为它会将某些输出发送到一个appender,然后将其余的输出发送到另一个appender。我能够使用LevelRangeFilter使其工作,如上所述。我想要ERROR,INFO和WARN去一个appender,所有其他人去另一个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>
谢谢, 尼克