私は重複を一生懸命探しましたが、それがどんなに基本的に見えるかもしれませんが、それを完全に明確にするために、次のことを尋ねなければなりません!
64 ビット W7 の VS28KSP1 で log4net バージョン 1.2.10.0 を使用する新しいコンソール アプリでは、次のコードがあります。
using log4net;
using log4net.Config;
namespace ConsoleApplication1
{
class Program
{
static readonly ILog _log = LogManager.GetLogger(typeof(Program));
static void Main(string[] args)
{
_log.Info("Ran");
}
}
}
私app.config
の には、次のものがあります。
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="Program.log" />
<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="1MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="[%username] %date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
</layout>
</appender>
<root>
<level value="DEBUG" />
<appender-ref ref="RollingFileAppender" />
</root>
</log4net>
</configuration>
属性を追加しない限り、これは何も書き込みません。
[ assembly:XmlConfigurator ]
または Main() で明示的に初期化します。
_log.Info("This will not go to the log");
XmlConfigurator.Configure();
_log.Info("Ran");
これにより、次の疑問が生じます。
- アセンブリ属性を追加したりメインで呼び出したりしなくても、log4net の一部のバージョンで動作しているのを見たことがあるとほぼ確信しています。誰かが私がそれを想像していないことを保証できますか?
- 誰かがドキュメントのどこに構成セクションと初期化フックの両方が必要であると明示的に述べているかを教えてもらえますか?
これがポリシーである理由を簡単に想像できます-驚きなどを避けるために初期化ステップを明示的にすることは、これが常にそうであるとは限らないことを思い出しているように見えるだけです...(そして通常、私は別のファイルに設定を持っています、通常、構成セクションを写真から取り除きます)