.NET 6 NLog進階範例

目的

  • 在寫nlog.config檔案時覺得怎麼有點複雜,我只是需要簡單的設定檔就好了,最後決定透過appsetting來做設定

  • 將log文件採用非同步寫入,可大幅提升效能

建立新專案

選擇ASP.NET Core Web API專案範本,並執行下一步 步驟1

設定新的專案

命名你的專案名稱,並選擇專案要存放的位置。 步驟2

其他資訊

直接進行下一步 步驟3

4.NuGet加入套件

  • NLog

  • NLog.Web.AspNetCore

範例4-1

編輯Program.cs檔

範例5-1

編輯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沒有

範例6-1

編輯WeatherForecastController.cs類別檔

範例7-1

執行結果

F5執行後,依照下列步驟操作,並確認結果 範例8-1

範例8-2

執行後查看log檔案,這次寫到C:\temp底下 範例8-3

  • 第一個紅框處顯示物件內容

  • 第二個紅框處顯示使用Get請求呼叫了WeatherForecast回傳狀態碼200用了54.3ms的時間 範例8-4

結論

最後其實會發現Serilog相對來說比較容易使用,也建議使用serilog

參考

黑暗執行緒 中文輸出為unicode問題 target參數中文解說 非同步使用方式與縮寫

範例檔

GitHub

Last updated