配置log4net以根据级别向不同的appender发送错误

gre*_*ade 42 configuration log4net log4net-configuration

我想将Info Level&above发送到XML appender和Error/Fatal Level到EventLog appender.

我认为我需要修改配置的根元素,但我正在努力学习语法.对于给定级别或级别的级别,将日志定向到正确的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>
Run Code Online (Sandbox Code Playgroud)

编辑:谢谢@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>
Run Code Online (Sandbox Code Playgroud)

Dan*_*rod 14

这可以使用appender中的thresholdfilter元素来完成.

请注意,阈值可以直接位于appender下,也可以作为包容性过滤器,或者在evaluator例如

<evaluator type="log4net.Core.LevelEvaluator">
  <threshold value="ERROR"/>
</evaluator>
Run Code Online (Sandbox Code Playgroud)

它适用于跳过缓冲(即时输出)的包容性过滤器.



完整解释(来源):

<threshold value="ERROR" />
Run Code Online (Sandbox Code Playgroud)

阈值在AppenderSkeleton几乎所有的appender中实现并因此得到支持.它只是一个简单的测试,用于忽略级别低于阈值的日志记录事件.早期检查阈值,因为简单的测试非常有效.

还有另一种方法可以使用过滤器指定与阈值相同的行为.过滤器非常灵活,因为它们是可插拔的,您还可以开发自己的自定义逻辑并将其插入过滤器链中.

<filter type="log4net.Filter.LevelRangeFilter">
    <levelMin value="ERROR" />
    <levelMax value="OFF" />
</filter>
Run Code Online (Sandbox Code Playgroud)

与阈值检查一样,过滤器在AppenderSkelton基类中实现,并且几乎所有appender都支持.上述过滤器具有相同的效果<threshold value="ERROR" />.这是一个LevelRangeFilter,将允许通过与范围内的任何级别的事件ERROR,以OFF(含).注意,这OFF是最高级别ALL的名称,相反是最低级别的名称.

过滤器具有很大的灵活性,因为可以将多个过滤器链接在一起,以便对输出的事件进行细粒度控制.因此,它们在性能方面也有较高的成本,链中的每个过滤器都是一个对象,并被要求决定正确的行动方案.在阈值过滤的简单情况下,应优先使用阈值属性而不是过滤器.

Evaluator由the实现,BufferingAppenderSkeleton因此仅由扩展此基类并提供缓冲支持的appender支持.SmtpAppender就是其中之一.

Evaluator是一个可插入的对象,BufferingAppenderSkeleton使用它来确定是否应该缓冲日志记录事件,而是立即写入/发送.如果Evaluator判定事件很重要,那么当前缓冲区的全部内容将与事件一起发送.评估程序不像阈值或过滤器那样起作用,因为它不会丢弃事件.


Fra*_*ein 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>
Run Code Online (Sandbox Code Playgroud)