c#的日誌插件NLog基本使用
阿新 • • 發佈:2018-01-12
nag async info 插件 sta pack hmm erro 完整
本文介紹c#的日誌插件NLog
安裝插件
創建logger
日誌級別
書寫日誌信息
配置
包裝器
布局
安裝插件
直接下載插件包 Install-Package NLog.Config
創建logger
使用LogManager創建Logger實例,最好一個類裏面一個Logger實例 寫法一 這種寫法,記錄的日誌文件,顯示的logger名字,是命名空間加上logger所在類的類名,如 ConsoleApp1.Program private static Logger mylogger = LogManager.GetCurrentClassLogger
日誌級別
級別由低到高 Trace 記錄完整的信息,一般只用在開發環境 Debug 記錄調試信息,沒有Trace信息完整,一般也只用在開發環境 Info 簡單的信息,一般用在生產環境 Warn 記錄警告信息,一些可以解決的小問題 Error 記錄報錯信息,一般都是Exceptions信息 Fatal 非常嚴重的錯誤信息
書寫日誌信息
logger.Trace("Sample trace message"
配置
最基礎的配置 第一步,打開NLog.config配置文件,添加如下配置 <targets> <target name="logfile" xsi:type="File" fileName="file.txt" /> // 創建一個target,代表輸出日誌文件的配置 </targets> <rules> <logger name="*" minlevel="Info" writeTo="logfile" /> // 設置Info級別以上的日誌,才能夠輸入到什麽名為logfile的target當中 /* 1.這裏logger自己還有一個name,這個name對應類名,也就是說什麽樣的類名可以輸出日誌,如ConsoleApp1.Program 2.可以添加final="true"屬性,表示後面的所有針對此指定名字的logger都無效 */ </rules> 第二步,運行代碼即可 多target配置 <targets> <target name="logfile" xsi:type="File" fileName="file.txt" /> <target name="console" xsi:type="Console" /> // 創建一個target表示用控制臺輸出日誌信息 </targets> <rules> <logger name="*" minlevel="Trace" writeTo="logfile" /> <logger name="*" minlevel="Info" writeTo="console" /> // 將Info級別以上的配置信息輸出到名為console的target中 </rules>
包裝器
異步包裝器配置 <targets> <target name="asyncFile" xsi:type="AsyncWrapper"> <target name="logfile" xsi:type="File" fileName="file.txt"/> </target> </targets> <rules> <logger name="*" minlevel="Trace" writeTo="asyncFile"/> </rules> 還有很多包裝器,按需自查
布局
布局是用來格式化日誌輸出信息的 simple日誌格式化 <target name="logfile" xsi:type="File" fileName="file.txt" layout="${date:format=yyyyMMddHHmmss} ${message} ${counter:increment=3:sequence=Layout:value=5}"/> 還有很多格式化寫法,自行查閱
子類繼承log
public class Demo1 { protected Logger Log { get; set; } protected Demo1() { Log = LogManager.GetLogger(GetType().FullName); } } public class Demo2: Demo1 { public Demo2():base() { } }
c#的日誌插件NLog基本使用