2

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

0 に答える 0