Log4net ведение журнала в двух разных файлах в одном приложении

Я использую log4net для ведения журнала. И мое приложение также использует quartz.net для планирования работы. Проблема в том, что журналы quartz.net и мои пользовательские журналы печатаются в одном файле журнала. Я ищу методы для входа в два разных файла, но не нашел решения. Может ли кто-нибудь подсказать мне, как настроить регистратор для входа в разные файлы, один файл для журналов quartz.net и другой файл для пользовательских журналов моего приложения.


person Ishtiaq    schedule 23.05.2014    source источник


Ответы (1)


Если у вас есть общее корневое пространство имен для вашего приложения, может сработать что-то вроде этого:

  <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>
person Marko Lahma    schedule 23.05.2014