如何在常见日志记录中存在记录器?

时间:2017-10-19 13:13:29

标签: c# common.logging

我在我的应用程序中使用Common.Logging并创建了一个单独的记录器来编写一些调试信息。

我可以使用

检索我的记录器
LogManager.GetLogger("MyCustomLogger");

但是,如果找不到此记录器,我会得到根记录器。我希望如果找不到记录器,则不会记录任何内容。由于我的应用程序的结构,我无法删除根记录器。

如何使用Common.Logging

来实现此行为

配置

<common>
    <logging>
      <factoryAdapter type="Common.Logging.Log4Net.Log4NetLoggerFactoryAdapter, Common.Logging.Log4net1213">
        <!-- Common Logging assumes that log4net is initialized -->
        <arg key="configType" value="EXTERNAL"/>
      </factoryAdapter>
    </logging>
  </common>

  <log4net>
    <appender name="FileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="Log/debug.txt"/>
      <appendToFile value="true"/>
      <maximumFileSize value="10000KB"/>
      <rollingStyle value="Size"/>
      <maxSizeRollBackups value="5"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%d{yyyy-MM-dd HH:mm:ss.fff} [%t] %-5p %c - %m%n"/>
      </layout>
    </appender>

    <appender name="MyCustomLogAppender" type="log4net.Appender.RollingFileAppender">
      <file value="Log/queries.txt" />
      <appendToFile value="true" />
      <maximumFileSize value="50000KB" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="5" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%d{yyyy-MM-dd HH:mm:ss.fff} [%t] %-5p %c - %m%n" />
      </layout>
    </appender>
    <!-- levels: DEBUG, INFO, WARN, ERROR, FATAL -->
    <root>
      <level value="DEBUG"/>
      <appender-ref ref="FileAppender"/>
    </root>

    <logger name="MyCustomLog" additivity="false">
      <level value="DEBUG" />
      <appender-ref ref="MyCustomLogAppender" />
    </logger>
  </log4net>

0 个答案:

没有答案