文本格式說明
可以記載的日志類別包括:FATAL(致命錯誤)、ERROR(一般錯誤)、WARN(警告)、INFO(一般信息)、DEBUG(調試信息)。
文本參數說明
%m(message):輸出的日志消息,如ILog.Debug(…)輸出的一條消息
%n(new line):換行
%d(datetime):輸出當前語句運行的時刻
%r(run time):輸出程序從運行到執行到當前語句時消耗的毫秒數
%t(thread id):當前語句所在的線程ID 等同於 %thread
%p(priority): 日志的當前優先級別,即DEBUG、INFO、WARN…等
%c(class):當前日志對象的名稱,例如:
模式字符串為:%-10c -%m%n
代碼為:
ILog log=LogManager.GetLogger(“Exam.Log”);
log.Debug(“Hello”);
則輸出為下面的形式:
Exam.Log - Hello
%L:輸出語句所在的行號
%F:輸出語句所在的文件名
%-數字:表示該項的最小長度,如果不夠,則用空格填充
%newline: 錯誤詳情
%message: 自定義輸出信息
%logger: 類
%property: 屬性
以下為個人定義的模板
%n==========
%n【日志級別】%-5level
%n【記錄時間】%date
%n【線程編號】[%thread]
%n【執行時間】[%r]毫秒
%n【出錯文件】%F
%n【出錯行號】%L
%n【出錯的類】%logger 屬性[%property{NDC}]
%n【錯誤描述】%message
%n【錯誤詳情】%newline
輸出示例:
==========
【日志級別】ERROR
【記錄時間】2012-11-08 15:49:37,625
【線程編號】[10]
【執行時間】[180]毫秒
【出錯文件】C:\Users\Administrator\Documents\Visual Studio 2010\Projects\ConsoleApplication5\ConsoleApplication5\Program.cs
【出錯行號】24
【出錯的類】ConsoleApplication5.Program 屬性[(null)]
【錯誤描述】錯誤
【錯誤詳情】
System.DivideByZeroException: 嘗試除以零。
在 ConsoleApplication5.Program.Main(String[] args) 位置 C:\Users\Administrator\Documents\Visual Studio 2010\Projects\ConsoleApplication5\ConsoleApplication5\Program.cs:行號 20
==========
【日志級別】ERROR
【記錄時間】2012-11-08 15:49:37,666
【線程編號】[10]
【執行時間】[221]毫秒
【出錯文件】C:\Users\Administrator\Documents\Visual Studio 2010\Projects\ConsoleApplication5\ConsoleApplication5\Program.cs
【出錯行號】28
【出錯的類】ConsoleApplication5.Program 屬性[(null)]
【錯誤描述】error
【錯誤詳情】
System.Exception: 發生了一個異常
使用說明:
配置文件:
節點: <configuration>中添加
<log4net> <!--定義輸出到文件中--> <appender name="SysAppender" type="log4net.Appender.RollingFileAppender"> <!--日志的路徑--> <file value="Logs/Log4Net/" /> <!--是否覆蓋,默認是追加true--> <appendToFile value="true"/> <rollingStyle value="Composite"/> <!--文件名稱--> <DatePattern value="yyyy-MM-dd'.log'"></DatePattern> <!--設置無限備份=-1 ,最大備份數為1000--> <param name="MaxSizeRollBackups" value="1000"/> <!--每個文件的大小--> <param name="MaximumFileSize" value="500KB"/> <!--名稱是否可以更改為false為可以更改--> <param name="StaticLogFileName" value="false"/> <layout type="log4net.Layout.PatternLayout"> <!--輸出格式--> <conversionPattern value="%n========== %n【日志級別】%-5level %n【記錄時間】%date %n【線程編號】[%thread] %n【執行時間】[%r]毫秒 %n【出錯文件】%F %n【出錯行號】%L %n【出錯的類】%logger 屬性[%property{NDC}] %n【錯誤描述】%message %n【錯誤詳情】%newline"/> </layout> </appender> <!--定義輸出到控制台命令行中--> <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender"> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%n========== %n【日志級別】%-5level %n【記錄時間】%date %n【線程編號】[%thread] %n【執行時間】[%r]毫秒 %n【出錯文件】%F %n【出錯行號】%L %n【出錯的類】%logger 屬性[%property{NDC}] %n【錯誤描述】%message %n【錯誤詳情】%newline"/> </layout> </appender> <!--定義輸出到windows事件中--> <appender name="EventLogAppender" type="log4net.Appender.EventLogAppender"> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%n========== %n【日志級別】%-5level %n【記錄時間】%date %n【線程編號】[%thread] %n【執行時間】[%r]毫秒 %n【出錯文件】%F %n【出錯行號】%L %n【出錯的類】%logger 屬性[%property{NDC}] %n【錯誤描述】%message %n【錯誤詳情】%newline"/> </layout> </appender> <!--定義日志的輸出媒介,下面定義日志以四種方式輸出。也可以下面的按照一種類型或其他類型輸出。--> <root> <!--文件形式記錄日志-->> <appender-ref ref="SysAppender"/> <!--控制台控制顯示日志--> <appender-ref ref="ConsoleAppender"/> <!--Windows事件日志--> <!--<appender-ref ref="EventLogAppender"/>--> <!-- 如果不啟用相應的日志記錄,可以通過這種方式注釋掉 <appender-ref ref="AdoNetAppender_Access" /> --> </root> </log4net>
代碼中:
引用
using log4net;
using System.Reflection
在命名空間中添加[紅色的內容]
[assembly: log4net.Config.XmlConfigurator(Watch = true)]
namespace ConsoleApplication5
調用示例:
using System; using System.Collections.Generic; using System.Text; using log4net; using System.Reflection; [assembly: log4net.Config.XmlConfigurator(Watch = true)] namespace ConsoleApplication5 { class Program { static void Main(string[] args) { //創建日志記錄組件實例 ILog log = log4net.LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); //記錄嚴重錯誤 log.Fatal("嚴重錯誤"); log.Fatal("嚴重錯誤", new Exception("發生了一個致命錯誤")); //記錄錯誤日志 log.Error("錯誤"); log.Error("錯誤", new Exception("發生了一個異常")); //記錄警告信息 log.Warn("警告"); log.Error("警告", new Exception("有一個警告信息")); //記錄一般信息 log.Info("一般信息"); log.Error("一般信息", new Exception("發出一個一般信息")); //記錄調試信息 log.Debug("調試信息"); log.Error("調試信息", new Exception("發生了一個調試信息")); Console.Read(); } } }
示例程序下載: 日志記錄插件_log4net.zip