簡體   English   中英

Log4Net / C# - 禁用默認日志記錄

[英]Log4Net/C# - Disable default logging

我在C#項目中使用log4net,在生產環境中,我想禁用所有日志記錄,但是當發生一些致命錯誤時,它應該將所有以前的512條消息記錄到一個文件中。我已經成功配置了這個,它是工作正常。 當發生致命錯誤時,它會將消息記錄到文件中。

但是當我從Visual Studio運行它時,我可以看到所有日志消息都寫入Output窗口,無論它是否是致命的。 (當我從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對象

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

[語言 - C#,.NET Framework - 3.5,Visual Studio 2008,log4net 1.2.10,項目類型 - WinForms]

刪除BasicConfigurator.Configure()行。 這就是該行的作用 - 添加指向Console.Out的ConsoleAppender。

如果應用程序是在發布模式下編譯的,您是否仍在Visual Studio中看到消息? log4net可能使用Debug.Write來顯示錯誤。 如果是這種情況,則這些消息不應出現在發布模式中。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM