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