Log4Net / C # - Wyłącz domyślne rejestrowanie

Używam log4net w projekcie C #, w środowisku produkcyjnym chcę wyłączyć wszystkie rejestracje, ale gdy wystąpi jakiś błąd krytyczny, powinien zalogować wszystkie poprzednie 512 wiadomości do pliku. Udało mi się to skonfigurować i to jest Dobrze pracować. Loguje wiadomości do pliku, gdy wystąpi błąd krytyczny.

Ale kiedy uruchamiam go z Visual Studio, widzę, że wszystkie komunikaty dziennika są zapisywane w oknie Output, niezależnie od tego, czy jest to Fatal czy nie. (Nie widzę tych komunikatów, gdy uruchamiam z Eksploratora Windows - moja aplikacja jest exe WinForm i nie ma okna Konsoli, aby zobaczyć wyjście)

Czy jest jakiś sposób na wyłączenie tego logowania? Potrzebuję moich dzienników tylko w pliku, również w przypadku wystąpienia błędu krytycznego.

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

W ten sposób konfiguruję go w statycznym inicjatorze Windows Forms.

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

I mam obiekt logger zainicjowany w konstruktorze WinForm

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

[język - C #, .NET Framework - 3.5, Visual Studio 2008, log4net 1.2.10, typ projektu - WinForms]

questionAnswers(2)

yourAnswerToTheQuestion