.NET 6 NLog進階範例
目的
在寫nlog.config檔案時覺得怎麼有點複雜,我只是需要簡單的設定檔就好了,最後決定透過appsetting來做設定
將log文件採用非同步寫入,可大幅提升效能
建立新專案
選擇ASP.NET Core Web API專案範本,並執行下一步 
設定新的專案
命名你的專案名稱,並選擇專案要存放的位置。 
其他資訊
直接進行下一步 
4.NuGet加入套件
NLog
NLog.Web.AspNetCore

編輯Program.cs檔

編輯appsetting.json
設定NLog,包含
throwConfigExceptions:設定檔錯誤時會跳exception
使用非同步方式寫入檔案
targets:設定輸出的格式,例如txt檔案或是Console顯示
rules:什麼情況要做什麼動作,例如log名稱為Microsoft.AspNetCore最小等級是warn時寫到Console
ILogger
NLog
Level 0
Trace
Trace
Level 1
Debug
Debug
Level 2
Information
Info
Level 3
Warning
Warn
Level 4
Error
Error
Level 5
Critical
Fatal
Level 6
None
NLog沒有

編輯WeatherForecastController.cs類別檔

執行結果
F5執行後,依照下列步驟操作,並確認結果 

執行後查看log檔案,這次寫到C:\temp底下 
第一個紅框處顯示物件內容
第二個紅框處顯示使用Get請求呼叫了WeatherForecast回傳狀態碼200用了54.3ms的時間

結論
最後其實會發現Serilog相對來說比較容易使用,也建議使用serilog
參考
黑暗執行緒 中文輸出為unicode問題 target參數中文解說 非同步使用方式與縮寫
範例檔
Last updated