2008-09-24 175 views
7

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

但是,當我從Visual Studio運行它時,我可以看到所有的日誌消息都被寫入輸出窗口,無論它是否是致命的。 (我不能看到這些消息時,我從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 Forms的靜態初始化程序中配置它的方法。

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

而且我在winform的構造函數初始化的記錄器對象

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

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

+0

是否所有內容都輸出到控制檯?當然,因爲你的winforms應用程序沒有控制檯,它只是按你想要的那樣進行記錄? – 2008-09-24 12:57:53

+2

由於所有控制檯調用都是同步的,因此它對性能至關重要。如果你有一堆後臺線程做記錄,那麼他們會受到嚴重的影響。 – 2008-09-24 13:05:02

回答

0

如果應用程序在發佈模式下編譯,您是否仍然在Visual Studio中看到消息? log4net有可能使用Debug.Write來顯示錯誤。如果是這種情況,那麼這些消息不應該以釋放模式出現。