.NET中使用NLog記錄日志

以前小編記錄日志使用的是Log4Net,雖然好用但和NLog比起來稍顯復(fù)雜。下面小編就和大伙分享一下NLog的使用方式:

引用NLog.Config

在使用NLog之前,我們要首先添加對NLog.Config的引用,這里小編使用NuGet來添加引用,在安裝NLog.Config時會同時安裝NLog.Schema和NLog包

輸出日志
//實例化Logger對象,默認logger的名稱是當前類的名稱(包括類所在的命名空間名稱)
Logger logger = LogManager.GetCurrentClassLogger();
//兩種記錄日志的方式
logger.Log(LogLevel.Warn, "warning");
//Info方法表示日志級別是Info
logger.Info(() => "record logger info");
配置NLog

只有代碼是不夠的,要想讓代碼發(fā)揮作用還要進行相關(guān)配置。我們在添加NLog.Config包后,項目中會自動添加一個名為NLog.config的文件,針對NLog的配置就寫在該文件中。

<targets>
    <!--xsi:type表示日志的輸出方式,F(xiàn)ile表示將日志寫到文件中-->
    <target name="logfile" xsi:type="File"  fileName="日志文件全名"/>
    <!--xsi:type="Console"表示將日志信息打印到控制臺上-->
    <target name="logConsole" xsi:type="Console"/>
</targets>

<rules>
    <logger name="*" minlevel="Info" writeTo="logfile"/>
    <!--name指的是程序代碼中l(wèi)ogger對象的名字,writeTo的值是配置文件中target的名字-->
    <logger name="Test.Program" minlevel="Debug" writeTo="logConsole"/>
</rules>
日志在控制臺上輸出結(jié)果
滾動日志

當需要記錄大量的日志信息時,若將日志信息都寫入同一個文件中顯然是不合適的,創(chuàng)建大量的日志文件來記錄日志信息也是沒有必要的。這時我們可以使用滾動日志的形式來記錄日志信息。NLog中滾動日志的配置如下:

<target name="logfile" xsi:type="File"
<!--主日志文件路徑,${basedir}表示當前應(yīng)用程序域所在的根目錄-->
fileName="${basedir}\Logs\log.txt"              
<!--archiveFileName表示滾動日志存放路徑,log.{#####}.txt是滾動日志文件名-->
archiveFileName="${basedir}\Archives\log.{#####}.txt"
      <!--每個日志文件大小的最大值(單位:字節(jié)),主日志文件超過大小超過該值時會將文件內(nèi)容寫入滾動日志并清空主日志文件內(nèi)容-->
       archiveAboveSize="1024"
       archiveNumbering="Rolling"
       concurrentWrites="true"
       <!--滾動日志文件上限數(shù),滾動日志文件數(shù)達到上限新的文件內(nèi)容會覆蓋舊文件內(nèi)容 -->
       maxArchiveFiles="2"
       keepFileOpen="false" />
存放日志目錄結(jié)構(gòu)

Archives文件夾中的滾動日志

滾動日志的更過配置方法可參考文章File target

日志文件格式配置

默認的日志輸出格式是:時間|日志級別|Logger對象名|日志內(nèi)容
我們可以使用target標簽的layout屬性來自定義日志輸出格式。

<target name="logfile" xsi:type="File" fileName="file.txt" 
layout="${date:format=yyyyMMddHHmmss} ${message}" />
使用自定義格式輸出日志內(nèi)容

另一種方式:

<target xsi:type="File" name="globalErrorLog" fileName="${basedir}\App_Data\Logs\log.txt"
     layout="${longdate}${newline}${message}${exception}${newline}----------${level} | ${logger}----------${newline}"
/>

日志輸出格式如下:


日志輸出格式

至于其它的格式,各位讀者可根據(jù)自己的需要來具體設(shè)定。

結(jié)語

日志可以幫助我們更好的調(diào)試程序,當系統(tǒng)出現(xiàn)問題時,我們可以通過日志來快速的定位到問題所在,因此在開發(fā)中日志的記錄十分重要。這里小編僅僅總結(jié)了使用NLog記錄日志的簡單用法,至于NLog的更多使用方式有興趣的讀者可以查看NLog官網(wǎng)的相關(guān)文檔。

參考文章:

Tutorial
Custom target
Configuration API
Configuration file
File target
Layout Renderers
FileTarget Header and Footer

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,461評論 6 532
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,538評論 3 417
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,423評論 0 375
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,991評論 1 312
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,761評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,207評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,268評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,419評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,959評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,782評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,983評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,528評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,222評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,653評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,901評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,678評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,978評論 2 374

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,785評論 18 139
  • Spring Boot 參考指南 介紹 轉(zhuǎn)載自:https://www.gitbook.com/book/qbgb...
    毛宇鵬閱讀 46,898評論 6 342
  • 在應(yīng)用程序中添加日志記錄總的來說基于三個目的:監(jiān)視代碼中變量的變化情況,周期性的記錄到文件中供其他應(yīng)用進行統(tǒng)計分析...
    時待吾閱讀 5,010評論 0 6
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,659評論 25 708
  • 過年后又恢復(fù)了2周1本書的閱讀節(jié)奏,這個月重新讀了《Rewrok》 收獲如下 1、失敗是成功之母,是個偽命題,有的...
    滄桑過客閱讀 351評論 0 0