.NET 6 配置使用NLog日志框架的方法及示例代码
NLog是一个流行的开源日志记录框架,用于在.NET应用程序中记录日志。它提供了强大的日志记录功能,具有灵活的配置选项和多种目标,可将日志记录到不同的输出位置,例如文件、数据库、控制台等。本文主要介绍.NET 6 中配置使用NLog,以及相关示例代码。
1、安装引用NLog
使用NLog需要安装引用NLog.Extensions.Hosting,如配置文件使用类似 ${aspnet-request-url} 的配置,以aspnet-开头的则需要安装 NLog.Web.AspNetCore。
1)NLog.Extensions.Hosting
在Nuget管理程序中,搜索 "NLog.Extensions.Logging",然后点击安装。
2)NLog.Web.AspNetCore
在Nuget管理程序中,搜索 "NLog.Web.AspNetCore",然后点击安装。
相关文档:
2、NLog 配置文件
NLog 中配置文件可以使用XML和JSONSON格式的, 具体如下,
1)XML格式的配置
<?xml version="1.0" encoding="utf-8" ?>
<nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
autoReload="true"
internalLogLevel="Info"
internalLogFile="${currentdir}/Logs/error.txt" >
<!-- enable asp.net core layout renderers -->
<extensions>
<add assembly="NLog.Web.AspNetCore"/>
</extensions>
<!-- the targets to write to -->
<targets>
<!-- File Target for all log messages with basic details -->
<target xsi:type="File" name="allfile" fileName="${currentdir}/Logs/${shortdate}/${level}/${level}.txt" maxArchiveFiles="30" enableArchiveFileCompression="true"
concurrentWrites="true"
keepFileOpen="true"
layout="${longdate}|${event-properties:item=EventId:whenEmpty=0}|${level:uppercase=true}|${logger}|${message} ${exception:format=tostring}" />
<!-- File Target for own log messages with extra web details using some ASP.NET core renderers -->
<target xsi:type="File" name="ownFile-web" fileName="${currentdir}/Logs/${shortdate}/${level}/web.txt" maxArchiveFiles="30"
layout="${longdate}|${event-properties:item=EventId:whenEmpty=0}|${level:uppercase=true}|${logger}|${message} ${exception:format=tostring}|url: ${aspnet-request-url}|action: ${aspnet-mvc-action}" />
<!--Console Target for hosting lifetime messages to improve Docker / Visual Studio startup detection -->
<target xsi:type="Console" name="lifetimeConsole" layout="${MicrosoftConsoleLayout}" />
</targets>
<!-- rules to map from logger name to target -->
<rules>
<!--All logs, including from Microsoft-->
<logger name="*" minlevel="Error" writeTo="allfile" />
<!--Output hosting lifetime messages to console target for faster startup detection -->
<logger name="Microsoft.Hosting.Lifetime" minlevel="Info" writeTo="lifetimeConsole, ownFile-web" final="true" />
<!--Skip non-critical Microsoft logs and so log only own logs (BlackHole) -->
<logger name="Microsoft.*" maxlevel="Info" final="true" />
<logger name="System.Net.Http.*" maxlevel="Info" final="true" />
<logger name="*" minlevel="Trace" writeTo="ownFile-web" />
</rules>
</nlog>
2)JSON配置文件
"NLog":{
"internalLogLevel":"Info",
"internalLogFile":"${currentdir}/Logs/error.log",
"extensions": [
{ "assembly": "NLog.Extensions.Logging" },
{ "assembly": "NLog.Web.AspNetCore" }
],
"targets":{
"allfile":{
"type":"File",
"fileName":"${currentdir}/Logs/${shortdate}/${level}/${level}.log",
"layout":"${longdate}|${event-properties:item=EventId_Id}|${uppercase:${level}}|${logger}|${message} ${exception:format=tostring}"
},
"ownFile-web":{
"type":"File",
"fileName":"${currentdir}/Logs/${shortdate}/${level}/${level}.log",
"layout":"${longdate}|${event-properties:item=EventId_Id}|${uppercase:${level}}|${logger}|${message} ${exception:format=tostring}|url: ${aspnet-request-url}|action: ${aspnet-mvc-action}"
}
},
"rules":[
{
"logger":"*",
"minLevel":"Trace",
"writeTo":"allfile"
},
{
"logger":"Microsoft.*",
"maxLevel":"Info",
"final":"true"
},
{
"logger":"*",
"minLevel":"Trace",
"writeTo":"ownFile-web"
}
]
}
3、NLog配置及使用示例
参考文档:
浙公网安备 33010602011771号