7

C# プロジェクトで log4net を使用しています。実稼働環境では、すべてのログ記録を無効にしたいのですが、致命的なエラーが発生した場合、以前の 512 メッセージをすべてファイルに記録する必要があります。これを正常に構成しました。正常に動作しています。致命的なエラーが発生すると、メッセージをファイルに記録します。

しかし、Visual Studio から実行すると、Fatal であるかどうかに関係なく、すべてのログ メッセージが [出力] ウィンドウに書き込まれていることがわかります。(Windows エクスプローラーから実行すると、これらのメッセージが表示されません。アプリケーションは WinForm exe であり、出力を表示するコンソール ウィンドウはありません)

このログを無効にする方法はありますか? 致命的なエラーが発生した場合にも、ファイルにのみログが必要です。

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <log4net debug="false">

        <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
            <file value="log.txt" />
            <appendToFile value="true" />
            <rollingStyle value="Size" />
            <maxSizeRollBackups value="10" />
            <maximumFileSize value="1MB" />
            <staticLogFileName value="true" />
            <layout type="log4net.Layout.PatternLayout">
                <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
            </layout>
        </appender>

        <appender name="BufferingForwardingAppender" type="log4net.Appender.BufferingForwardingAppender" >
            <bufferSize value="512" />
            <lossy value="true" />
            <evaluator type="log4net.Core.LevelEvaluator">
                <threshold value="FATAL"/>
            </evaluator>
            <appender-ref ref="RollingFileAppender" />
        </appender> 

        <root>
            <level value="DEBUG" />
            <appender-ref ref="BufferingForwardingAppender" />          
        </root>
    </log4net>
</configuration>

そして、これが Windows フォームの静的イニシャライザーで構成する方法です。

static Window1()
    {
      Stream vStream = typeof(Window1).Assembly.GetManifestResourceStream("TestLogNet.log4net.config");
      XmlConfigurator.Configure(vStream);
      BasicConfigurator.Configure();
    }

そして、WinFormのコンストラクターで初期化されたロガーオブジェクトを持っています

logger = LogManager.GetLogger(typeof(Window1));

[言語 - C#、.NET Framework - 3.5、Visual Studio 2008、log4net 1.2.10、プロジェクト タイプ - WinForms]

4

2 に答える 2

7

BasicConfigurator.Configure()行を削除します。それがその行の動作です -- Console.Out を指す ConsoleAppender を追加します。

于 2008-09-24T13:14:39.393 に答える
0

アプリケーションがリリース モードでコンパイルされている場合でも、Visual Studio にメッセージが表示されますか? とにかく、log4net が Debug.Write を使用してエラーを表示する可能性があります。その場合、これらのメッセージはリリース モードで表示されません。

于 2008-09-24T13:12:47.200 に答える