C#使用Log4net實(shí)現(xiàn)將日志輸出到控制臺(tái)或者文本文檔
背景
最近在最一些并發(fā)方式的測(cè)試,發(fā)現(xiàn)自己之前封裝的一個(gè)日志插件報(bào)錯(cuò),盡管在寫日志時(shí)已經(jīng)通過(guò)鎖的方式進(jìn)行了優(yōu)化,但是依然無(wú)法解決并發(fā)時(shí)同一個(gè)文件同時(shí)訪問(wèn)情況,會(huì)頻繁出現(xiàn)報(bào)錯(cuò)提示xxx.txt文件正在被另一個(gè)進(jìn)程訪問(wèn)而不無(wú)法操作。
基于這個(gè)原因,暫時(shí)沒(méi)有想好很好的優(yōu)化方案,從而考慮使用第三方優(yōu)秀日志插件來(lái)解決并發(fā)情況。
插件簡(jiǎn)介
Log4net 是一個(gè)穩(wěn)定且功能豐富的日志庫(kù),已經(jīng)存在多年并且被廣泛使用。
它支持多種輸出目標(biāo)和格式,可以滿足各種日志記錄需求。
Log4net 具有靈活的配置選項(xiàng),允許你根據(jù)需要定制日志記錄行為。
插件安裝
在項(xiàng)目中添加對(duì) Log4net 的引用。可以使用 NuGet 包管理器來(lái)安裝 Log4net。
選擇一個(gè)合適版本進(jìn)行安裝,博主這里選擇最新版本安裝。
配置文件
日志類型
在 log4net 中,日志類型一般分為以下幾種,對(duì)應(yīng)不同的日志級(jí)別:
1.DEBUG
最詳細(xì)的日志級(jí)別,通常用于打印一些調(diào)試信息,僅在開發(fā)和調(diào)試階段使用,生產(chǎn)環(huán)境中通常不會(huì)記錄 DEBUG 級(jí)別的日志。
2.INFO
用于記錄程序正常運(yùn)行時(shí)的重要信息,比如服務(wù)啟動(dòng)、關(guān)鍵流程開始或結(jié)束等。對(duì)于用戶而言,通常不需要關(guān)注 INFO 級(jí)別的日志,但這些日志對(duì)于開發(fā)人員來(lái)說(shuō)非常重要。
3.WARN
表明潛在的問(wèn)題,但不會(huì)影響系統(tǒng)正常運(yùn)行,比如某個(gè)接口請(qǐng)求參數(shù)不合法,程序采取了默認(rèn)值處理;或者磁盤空間不足,但系統(tǒng)仍然能夠正常運(yùn)行。WARN 級(jí)別的日志用于提示開發(fā)人員和運(yùn)維人員需要注意的問(wèn)題。
4.ERROR
用于記錄錯(cuò)誤事件,但不會(huì)導(dǎo)致程序終止。比如捕獲到了一個(gè)異常,程序進(jìn)行了相應(yīng)的處理,不會(huì)導(dǎo)致程序崩潰。ERROR 級(jí)別的日志通常需要開發(fā)人員及時(shí)關(guān)注并處理。
5.FATAL
表示嚴(yán)重的錯(cuò)誤事件,可能導(dǎo)致程序終止。比如未捕獲的異常、數(shù)據(jù)庫(kù)連接失敗等致命錯(cuò)誤。FATAL 級(jí)別的日志表示系統(tǒng)出現(xiàn)了嚴(yán)重的錯(cuò)誤,需要立即處理。
文件詳情
此配置文件內(nèi)容,按日志級(jí)別創(chuàng)建文件,按時(shí)間年月日時(shí)來(lái)創(chuàng)建文件名,同一小時(shí)內(nèi)超過(guò)10M文件大小則拆分文件保存。
<?xml version="1.0" encoding="utf-8" ?> <log4net> <!--定義日志級(jí)別--> <root> <level value="FATAL"/> <level value="ERROR"/> <level value="WARN"/> <level value="INFO"/> <level value="DEBUG"/> <appender-ref ref="FATALAppender" /> <appender-ref ref="ERRORAppender" /> <appender-ref ref="WARNAppender" /> <appender-ref ref="INFOAppender" /> <appender-ref ref="DebugAppender" /> </root> <!--嚴(yán)重錯(cuò)誤日志--> <appender name="FATALAppender" type="log4net.Appender.RollingFileAppender"> <file type="log4net.Util.PatternString" value="logs\Fatal\%date{yyyyMMddHH}.log" /> <appendToFile value="true" /> <rollingStyle value="Size" /> <staticLogFileName value="false"/> <maximumFileSize value="100KB"/> <maxSizeRollBackups value="-1"/> <lockingModel type="log4net.Appender.FileAppender+MinimalLock" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger - %message - %line" /> </layout> </appender> <!--調(diào)試日志--> <appender name="DebugAppender" type="log4net.Appender.RollingFileAppender"> <file type="log4net.Util.PatternString" value="logs\Debug\%date{yyyyMMddHH}.log" /> <appendToFile value="true" /> <rollingStyle value="Size" /> <staticLogFileName value="false"/> <maximumFileSize value="100KB"/> <maxSizeRollBackups value="-1"/> <lockingModel type="log4net.Appender.FileAppender+MinimalLock" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger - %message - %line" /> </layout> </appender> </log4net>
通過(guò)使用不同級(jí)別的日志記錄,開發(fā)人員和運(yùn)維人員可以更好地了解系統(tǒng)的運(yùn)行情況,及時(shí)發(fā)現(xiàn)潛在問(wèn)題,并采取相應(yīng)的措施進(jìn)行處理。
日志設(shè)置
命名空間
using log4net; using log4net.Config; using System.Reflection;
實(shí)例化
// 日志插件 var logRepository = LogManager.GetRepository(Assembly.GetEntryAssembly()); XmlConfigurator.Configure(logRepository, new FileInfo(Path.Combine(AppContext.BaseDirectory, "log4net.config")));
日志調(diào)用
private static readonly ILog log = LogManager.GetLogger(typeof(SqlHelper)); public void Test() { log.Fatal("Fatal message"); log.Debug("Debug message"); log.Info("Info message"); log.Warn("Warn message"); log.Error("Error message"); }
輸出控制臺(tái)
根據(jù)上面默認(rèn)配置文件信息,日志信息輸出到控制臺(tái)里。
使用的類型是log4net.Appender.ConsoleAppender
<?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 - %message%line" /> </layout> </appender> <root> <level value="DEBUG" /> <appender-ref ref="ConsoleAppender" /> </root> </log4net>
輸出文本文檔
根據(jù)上面默認(rèn)配置文件信息,日志信息輸出到文本文檔里。
使用的類型是log4net.Appender.Appender.RollingFileAppender
<?xml version="1.0" encoding="utf-8" ?> <log4net> <!--定義日志級(jí)別--> <root> <level value="DEBUG"/> <appender-ref ref="DebugAppender" /> </root> <!--調(diào)試日志--> <appender name="DebugAppender" type="log4net.Appender.RollingFileAppender"> <file type="log4net.Util.PatternString" value="logs\Debug\%date{yyyyMMddHH}.log" /> <appendToFile value="true" /> <rollingStyle value="Size" /> <staticLogFileName value="false"/> <maximumFileSize value="100KB"/> <maxSizeRollBackups value="-1"/> <lockingModel type="log4net.Appender.FileAppender+MinimalLock" /> <layout type="log4net.Layout.PatternLayout"> <conversionPattern value="%date [%thread] %-5level %logger - %message - %line" /> </layout> </appender> </log4net>
到此這篇關(guān)于C#使用Log4net實(shí)現(xiàn)將日志輸出到控制臺(tái)或者文本文檔的文章就介紹到這了,更多相關(guān)C# Log4net日志輸出內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C#實(shí)現(xiàn)操作PPT動(dòng)畫窗格并插入音頻文件
這篇文章主要為大家詳細(xì)介紹了如何利用C#實(shí)現(xiàn)操作PPT動(dòng)畫窗格并插入音頻文件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-10-10