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

What's wrong with my log4net config file

我有一个包含两个附加程序的配置文件,一个文件附加程序和一个数据库附加程序。我想将所有内容记录到文件附加程序,并且只将异常记录到数据库附加程序。在本节中设置两个 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>

你这里有以下内容:

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

据我了解,您希望所有日志都默认保存到文件中,只有错误日志也保存到数据库中。然后只需将两个附加程序添加到您的根记录器,以便两者都获取所有事件,并添加过滤器以仅让您感兴趣的过滤器通过:数据库附加程序上的级别范围过滤器将起作用

<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>

当然,如果您不想要任何重复项,只需在滚动文件附加程序中过滤错误及以上内容