C# Winform使用log4net進行日志記錄
寫在前面
Log4Net是從Java的log4j移植過來的,功能也與log4j類似,可以把日志信息輸出到文件、數(shù)據(jù)庫、控制臺、Windows 事件日志、遠程系統(tǒng)日志服務(wù)等不同的介質(zhì)或目標。
Log4Net配置選項豐富靈活,并且可在運行時動態(tài)更新配置并應(yīng)用,允許同時推送到多個目標;雖然項目已經(jīng)休眠了,但是該類庫已久經(jīng)考驗,經(jīng)典的設(shè)計永不過時。
獲取類庫
可通過NuGet獲取類庫,引入到項目中。
配置模板
新建log4net.xml文件,命名成log4net.config也可以,初始化時保持一致即可,配置內(nèi)容如下:
<?xml version="1.0" encoding="utf-8"?> <log4net> <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender"> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger %ndc - %message%newline" /> </layout> </appender> <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="INFO"> <!--防止多線程時不能寫Log,官方說線程非安全--> <param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" /> <param name="File" value="Logs/" /> <param name="AppendToFile" value="true"/> <param name="StaticLogFileName" value="false" /> <param name="DatePattern" value="yyyy-MM-dd.'info.log'" /> <param name="RollingStyle" value="Date"/> <param name="MaxSizeRollBackups" value="10" /> <param name="MaximumFileSize" value="5MB" /> <layout type="log4net.Layout.PatternLayout"> <param name="ConversionPattern" value="## %d [%t] %-5p %x %m %n"/> <!--<param name="ConversionPattern" value="%date [%thread] %-5level [%logger] %ndc - %message%newline" />--> </layout> <filter type="log4net.Filter.LevelRangeFilter"> <param name="LevelMin" value="INFO" /> <param name="LevelMax" value="INFO" /> </filter> </appender> <appender name="ErrorFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="ERROR"> <param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" /> <param name="File" value="Logs/" /> <param name="AppendToFile" value="true"/> <param name="StaticLogFileName" value="false" /> <param name="DatePattern" value="yyyy-MM-dd.'error.log'" /> <param name="RollingStyle" value="Date"/> <param name="MaxSizeRollBackups" value="10" /> <param name="MaximumFileSize" value="5MB" /> <layout type="log4net.Layout.PatternLayout"> <param name="ConversionPattern" value="%date [%thread] %-5level [%logger] %ndc - %message%newline" /> </layout> <filter type="log4net.Filter.LevelRangeFilter"> <param name="LevelMin" value="WARN" /> <param name="LevelMax" value="ERROR" /> </filter> </appender> <appender name="DebugFileAppender" type="log4net.Appender.RollingFileAppender" LEVEL="ERROR"> <param name="LockingModel" type="log4net.Appender.FileAppender+MinimalLock" /> <param name="File" value="Logs/" /> <param name="AppendToFile" value="true"/> <param name="StaticLogFileName" value="false" /> <param name="DatePattern" value="yyyy-MM-dd.'debug.log'" /> <param name="RollingStyle" value="Date"/> <param name="MaxSizeRollBackups" value="10" /> <param name="MaximumFileSize" value="5MB" /> <layout type="log4net.Layout.PatternLayout"> <param name="ConversionPattern" value="%date [%thread] %-5level [%logger] %ndc - %message%newline" /> </layout> <filter type="log4net.Filter.LevelRangeFilter"> <param name="LevelMin" value="DEBUG" /> <param name="LevelMax" value="DEBUG" /> </filter> </appender> <root> <level value="All" /> <appender-ref ref="LogFileAppender" /> <appender-ref ref="ErrorFileAppender"/> <appender-ref ref="DebugFileAppender" /> <appender-ref ref="ConsoleAppender" /> </root> </log4net>
將文件屬性中的“復(fù)制到輸出目錄”配置為始終復(fù)制,這樣配置文件會同步置執(zhí)行或發(fā)布目錄。
引用并初始化類庫
static Program() { //加載log4net配置 log4net.Config.XmlConfigurator.ConfigureAndWatch(new FileInfo(AppDomain.CurrentDomain.BaseDirectory + @"\log4net.xml")); }
也可以在AssemblyInfo.cs中進行初始化配置
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4Net.xml")]
工具類
public static class LogHelper { public static void Info(object msg, params object[] parameters) { var log = LogManager.GetLogger("log4netlogger"); log.Info(msg); } public static void Debug(string msg) { var log = LogManager.GetLogger("log4netlogger"); log.Debug(msg); } public static void Error(string msg) { var log = LogManager.GetLogger("log4netlogger"); log.Error(msg); } public static void FormatError(string format, params object[] args) { var log = LogManager.GetLogger("log4netlogger"); log.Error(string.Format(format, args)); } public static void Error(Exception ex) { var log = LogManager.GetLogger("log4netlogger"); log.Error(ex.Message, ex); } public static void Error(object msg, Exception ex) { var log = LogManager.GetLogger("log4netlogger"); log.Error(msg, ex); } public static void Warn(object msg, Exception ex) { var log = LogManager.GetLogger("log4netlogger"); log.Warn(msg, ex); } public static void Log(string msg) { Info(msg); } public static void Log(Exception ex) { Error(ex); } }
調(diào)用示例
LogHelper.Info("事件類型出錯,類型:" + _rv.EventType + ",參數(shù):" + _rv.EventArgs); LogHelper.Debug(string.Format("action_finish:{0}", TacticsName)); LogHelper.Error(string.Format("json序列化失敗:{0}", json), ex);
到此這篇關(guān)于C# Winform使用log4net進行日志記錄的文章就介紹到這了,更多相關(guān)C# log4net記錄日志內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
sqlserver備份還原數(shù)據(jù)庫功能封裝分享
這篇文章主要介紹了sqlserver備份還原數(shù)據(jù)庫功能封裝示例,需要的朋友可以參考下2014-03-03c#讀取圖像保存到數(shù)據(jù)庫中(數(shù)據(jù)庫保存圖片)
這篇文章主要介紹了使用c#讀取圖像保存到數(shù)據(jù)庫中的方法,大家參考使用吧2014-01-01詳解Unity中Mask和RectMask2D組件的對比與測試
本篇文章給大家介紹Unity中Mask和RectMask2D組件的對比與測試,包括組件用法及RectMask2D的基本用法,通過Mask的原理分析實例代碼相結(jié)合給大家講解的非常詳細,需要的朋友參考下吧2021-06-06C#創(chuàng)建數(shù)據(jù)庫及附加數(shù)據(jù)庫的操作方法
這篇文章主要介紹了C#創(chuàng)建數(shù)據(jù)庫及附加數(shù)據(jù)庫的操作方法,涉及C#針對數(shù)據(jù)庫常見的創(chuàng)建、添加、連接等操作技巧,需要的朋友可以參考下2016-06-06