Log4net在同一个应用程序中记录两个不同的文件

时间:2014-05-23 06:22:31

标签: logging log4net quartz.net log4net-configuration

我正在使用log4net进行日志记录。我的应用程序也使用quartz.net进行作业调度。问题是quartz.net日志和我的自定义日志都在同一个日志文件中打印。我正在寻找登录两个不同文件的方法,但没有找到解决方案。任何人都可以指导我如何配置记录器以登录不同的文件,一个文件用于quartz.net日志,其他文件用于我的应用程序的自定义日志。

1 个答案:

答案 0 :(得分:2)

如果你的应用程序有一个共同的根命名空间,那么这样的东西可能会起作用:

  <log4net>
    <appender name="QuartzFileAppender" type="log4net.Appender.RollingFileAppender">
      <file type="log4net.Util.PatternString" value="quartznet.log" />
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
      <appendToFile value="true" />
      <rollingStyle value="Composite" />
      <datePattern value="yyyyMMdd" />
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="1MB" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
      </layout>
    </appender>
    <appender name="AppFileAppender" type="log4net.Appender.RollingFileAppender">
      <file type="log4net.Util.PatternString" value="app.log" />
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
      <appendToFile value="true" />
      <rollingStyle value="Composite" />
      <datePattern value="yyyyMMdd" />
      <maxSizeRollBackups value="10" />
      <maximumFileSize value="1MB" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
      </layout>
    </appender>
    <logger name="Quartz">
      <level value="INFO" />
      <appender-ref ref="QuartzFileAppender" />
    </root> 
    <logger name="YourAppRootNameSpace">
      <level value="INFO" />
      <appender-ref ref="AppFileAppender" />
    </root>
  </log4net>