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