我的log4net配置文件有什么问题

时间:2015-05-11 19:55:17

标签: log4net

我有一个包含两个appender,一个文件appender和一个数据库appender的配置文件。我想将所有内容记录到文件appender,并且只记录数据库appender的异常。在部分中设置两个appender时,它记录正​​常,但所有日志事件都发送到两个appender,这不是我想要的。

我更改了配置但是使用当前配置,异常会记录到数据库中,并且没有任何内容被写入文件追加器。任何人都可以告诉我为什么我没有写任何文件appender?

<log4net debug="true">
    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="C:\Log4net\Workflow\TestLog.txt" />
      <threshold value="All" />
      <appendToFile value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="10KB" />
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%-5p {%logger} %d %5rms %-22.22c{1} %-18.18M - %m%n" />
      </layout>
    </appender>
    <appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">
      <!-- Removed to keep this snippet simple-->
    </appender>
    <root>
      <level value="Error" />
      <appender-ref ref="AdoNetAppender" />
    </root>
    <logger name="AllLogs">
        <level value="ALL" />
        <appender-ref ref="RollingLogFileAppender" />      
    </logger>

  </log4net>

1 个答案:

答案 0 :(得分:1)

您在此处拥有以下内容:

  • 级别为Error或更高级别的所有日志事件都将转到AdoNetAppender
  • 来自名称基于AllLogs的记录器的所有日志事件都将转到RollingLogFileAppender

根据我的理解,您希望所有日志都默认为该文件,并且只有错误的日志也会转到数据库。然后只需将两个appender添加到根记录器中,以便同时获取所有事件,并添加过滤器以仅让您感兴趣的过滤器通过:数据库appender上的级别范围过滤器可以使用

<log4net debug="true">

    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
        <!-- rest of config snipped to save space -->
    </appender>
    <appender name="AdoNetAppender" type="log4net.Appender.AdoNetAppender">
        <filter type="log4net.Filter.LevelRangeFilter">
            <levelMin value="ERROR" />
            <levelMax value="FATAL" />
        </filter>
        <!-- rest of config snipped to save space -->
    </appender>

    <root>
        <appender-ref ref="AdoNetAppender" />
        <appender-ref ref="RollingLogFileAppender" />   
    </root>
</log4net>

当然,如果你不想在滚动文件appender

中只是重复过滤错误