<?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();