Log4Net 配置詳解


<?xml version="1.0"?>
<configuration>
  <configSections>
    <section name="log4net" 
             type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
  </configSections>
  <!--站點日志配置部分-->
  <log4net>
    <root>
      <!--控制級別,由低到高: ALL|DEBUG|INFO|WARN|ERROR|FATAL|OFF-->
      <!--比如定義級別為INFO,則INFO級別向下的級別,比如DEBUG日志將不會被記錄-->
      <!--如果沒有定義LEVEL的值,則缺省為DEBUG-->
      <level value="ERROR"/>
      <appender-ref ref="RollingFileAppender"/>
    </root>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <!--日志文件名開頭-->
      <file value="c:\Log\TestLog4net.TXT"/>
      <!--多線程時采用最小鎖定-->
      <lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
      <!--日期的格式,每天換一個文件記錄,如不設置則永遠只記錄一天的日志,需設置-->
      <datePattern value="(yyyyMMdd)"/>
      <!--是否追加到文件,默認為true,通常無需設置-->
      <appendToFile value="true"/>
      <!--變換的形式為日期,這種情況下每天只有一個日志-->
      <!--此時MaxSizeRollBackups和maximumFileSize的節點設置沒有意義-->
      <!--<rollingStyle value="Date"/>-->
      <!--變換的形式為日志大小-->
      <!--這種情況下MaxSizeRollBackups和maximumFileSize的節點設置才有意義-->
      <RollingStyle value="Size"/>
      <!--每天記錄的日志文件個數,與maximumFileSize配合使用-->
      <MaxSizeRollBackups value="10"/>
      <!--每個日志文件的最大大小-->
      <!--可用的單位:KB|MB|GB-->
      <!--不要使用小數,否則會一直寫入當前日志-->
      <maximumFileSize value="2MB"/>
      <!--日志格式-->
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%t]%-5p %c - %m%n"/>
      </layout>
    </appender>
  </log4net>
</configuration>

  

 

using System;
using System.Reflection;
using log4net;
using log4net.Config;
namespace Log4Net1001
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Begin Run");
            XmlConfigurator.Configure();
            Type type = MethodBase.GetCurrentMethod().DeclaringType;
            ILog m_log = LogManager.GetLogger(type);
            m_log.Debug("這是一個Debug日志");
            m_log.Info("這是一個Info日志");
            m_log.Warn("這是一個Warn日志");
            m_log.Error("這是一個Error日志");
            m_log.Fatal("這是一個Fatal日志");
            Console.WriteLine("End");
            Console.ReadLine();
        }
    }
}

  運行結果,在c:\Log\TestLog4net.TXT文件中寫了如下信息:
        2013-10-01 22:35:53,793 [10]ERROR Log4Net1001.Program - 這是一個Error日志
        2013-10-01 22:35:53,802 [10]FATAL Log4Net1001.Program - 這是一個Fatal日志

        其中layout節點的配置說明:
        %m(message):輸出的日志消息;
        %n(newline):換行;
        %d(datetime):輸出當前語句運行的時刻;
        %r(runtime):輸出程序從運行到執行到當前語句時消耗的毫秒數;
        %t(threadid):當前語句所在的線程ID ;
        %p(priority): 日志的當前日志級別;
        %c(class):當前日志對象的名稱;
        %L:輸出語句所在的行號;
        %F:輸出語句所在的文件名; 
        %-10:表示最小長度為10,如果不夠,則用空格填充;

 

其他開發時遇到的問題
        1.項目的目標框架為.NET Framework 3.5(或者4) Client Profile時會報出下圖錯誤,改成.NET Framework 3.5(或者4) 即可;

 

         2.當configSections節點沒有放在configuration節點下的第一個節點時,編譯時不會報警告,但運行時不會記日志。這是因為自定義的節點configSections這個必須放在第一個,這是app.config文件的語法規定;

        3.對於大量記日志的程序,需注意配置RollingStyle值為Composite,且設置MaxSizeRollBackups(每天記錄的日志文件個數)和maximumFileSize(每個日志文件的最大大小)。我以前遇過一次日志過大的問題,有一次版本臨時發布就改了一個方法而沒有經過測試,造成每天記幾十G日志的,幾天就把服務器磁盤弄滿了。

        4.當發現不記日志時,可從兩方面調查問題,一是log4net有沒有初始化,也就是XmlConfigurator.Configure();二是看level節點的配置是不是正確;

        5.當發現一些設置參數沒有起作用時,請檢查是不是同一個節點被設置過多次,當被重復設置時,log4net會選擇最后一個作為實際的設置。例如設置記錄日志的級別設置兩次如<level value="ERROR"/><level value="All"/>,則最終會以ALL作為記錄日志的級別。

        6.如果是網站項目,須在項目中的AssemblyInfo.cs文件的最后一行中添加:

[assembly: log4net.Config.DOMConfigurator(ConfigFile = "Web.config", Watch = true)] 

  7.缺少下面代碼,可能會導致日志寫不上去。

log4net.Config.XmlConfigurator.Configure();

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM