C# 日誌的配置流程
轉載自https://www.cnblogs.com/SuperMetalMax/p/6203188.html
1. 下載log4net.dll文件
http://download.csdn.net/detail/abc456456456456/7653857
2. 項目中引用此dll
3. appconfig中配置log4net
<?xml version="1.0" encoding="utf-8"?> <configuration> <configSections> <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" /> </configSections> <log4net> <!-- 日誌文件配置--> <root> <level value="ALL" /> <appender-ref ref="RollingLogFileAppender" /> </root> <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender"> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" /> </layout> </appender> <appender name="FileAppender" type="log4net.Appender.FileAppender"> <file value="logs/dd/%date.txt" /> <appendToFile value="true" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" /> </layout> </appender> <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender"> <param name="File" value="logs\\" /> <param name="AppendToFile" value="true" /> <param name="MaxSizeRollBackups" value="10" /> <param name="StaticLogFileName" value="false" /> <param name="DatePattern" value="yyyy-MM-dd".log"" /> <param name="RollingStyle" value="Date" /> <layout type="log4net.Layout.PatternLayout"> <param name="ConversionPattern" value="%date [%thread] %-5level %logger MapConnectStringproperty{NDC}] - %message%newline" /> </layout> </appender> </log4net> </configuration>
配置說明:
<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>
其中layout節點的配置說明:
%m(message):輸出的日誌消息;
%n(newline):換行;
%d(datetime):輸出當前語句運行的時刻;
%r(runtime):輸出程序從運行到執行到當前語句時消耗的毫秒數;
%t(threadid):當前語句所在的線程ID ;
%p(priority): 日誌的當前日誌級別;
%c(class):當前日誌對象的名稱;
%L:輸出語句所在的行號;
%F:輸出語句所在的文件名;
%-10:表示最小長度為10,如果不夠,則用空格填充;
4. AssemblyInfo.cs 中添加"[assembly: log4net.Config.XmlConfigurator(Watch = true)]"
[assembly: log4net.Config.XmlConfigurator(Watch = true)]
5.Winform中調用
private static readonly log4net.ILog Logger = log4net.LogManager.GetLogger(typeof(FrmLog)); Logger.Debug("測試debug");
註意:
1.如果出現"類型初始值設定項引發異常"類似的文字,首先查看 app.config配置中 <configSections> 元素,必須是根<configuration> 元素的第一個子元素。
2.項目的目標框架為.NET Framework 3.5(或者4) Client Profile時會報出下圖錯誤,改成.NET Framework 3.5(或者4) 即可。
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)]
C# 日誌的配置流程