C# ASP.NET Core 2.1站点的nlog设置
我正在尝试将nlog设置为登录到3个单独的日志文件中。我希望实体框架的东西转到一个日志文件(db.log)。我只希望与应用程序相关的日志记录转到另一个日志文件(own.log)。最后,我希望其他所有东西(微软的东西)都转到另一个文件(all.log) 这就是我在下面所做的,但是我不能根据我的要求让日志工作。我做错了什么 提前谢谢C# ASP.NET Core 2.1站点的nlog设置,c#,asp.net-core,nlog,C#,Asp.net Core,Nlog,我正在尝试将nlog设置为登录到3个单独的日志文件中。我希望实体框架的东西转到一个日志文件(db.log)。我只希望与应用程序相关的日志记录转到另一个日志文件(own.log)。最后,我希望其他所有东西(微软的东西)都转到另一个文件(all.log) 这就是我在下面所做的,但是我不能根据我的要求让日志工作。我做错了什么 提前谢谢 <?xml version="1.0" encoding="utf-8" ?> <nlog xmlns="http://www.nlog-projec
<?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"
internalLogFile="internal.log"
internalLogLevel="info" >
<!-- enable asp.net core layout renderers -->
<extensions>
<add assembly="NLog.Web.AspNetCore"/>
</extensions>
<!-- the targets to write to -->
<targets>
<!-- write logs to file -->
<target xsi:type="File" name="allfile"
fileName="all-${shortdate}.log"
layout="${longdate}|${event-properties:item=EventId_Id}|${uppercase:${level}}|${logger}|${message} ${exception:format=tostring}" />
<!-- another file log, only own logs. Uses some ASP.NET core renderers -->
<target xsi:type="File" name="ownFile-web"
fileName="own-${shortdate}.log"
layout="${longdate}|${activityid}|${level:uppercase=true}|${message} ${exception:format=ToString}|${logger}|${all-event-properties}|url: ${aspnet-request-url}|action: ${aspnet-mvc-action}" />
<target xsi:type="File" name="sqllogfile"
fileName="db-${shortdate}.log"
layout="${date}|${activityid}|${level:uppercase=true}|${message} ${exception}|${logger}|${all-event-properties}" />
</targets>
<!-- rules to map from logger name to target -->
<rules>
<!--All logs, including from Microsoft-->
<logger name="*" minlevel="Trace" writeTo="allfile" />
<!--Skip Microsoft logs and so log only own logs-->
<logger name="Microsoft.EntityFrameworkCore.*" minlevel="Trace" writeTo="sqllogfile" final="true" />
<logger name="Microsoft.*" maxlevel="Info" final="true" />
<!-- Our log -->
<logger name="*" minlevel="Trace" writeTo="ownFile-web" />
</rules>
</nlog>
移动数据库日志是关键。另外,在将“捕获所有日志”移到底部后,我现在可以得到正确的日志记录结果。请告诉我哪些有效,哪些无效。相反,它几乎不起作用。通过配置throwconfigeexceptions=“true”
是个好主意。你检查过NLog内部日志了吗?我没有得到想要的结果。通过发布的配置,我在单独的文件中获得实体框架日志记录,但在all.log文件中也会出现相同的数据库日志记录。而且我没有单独的own.log文件,只记录应用程序。相反,我在all.log文件中获取所有内容。使用EntityFrameworkCore
将日志规则移动到规则部分的顶部。然后它将不会到达allFile
(我想您应该重命名目标,因为它现在不是“allFile”)。您能否从allFile
中举出一个本应到达ownFile
的示例?(想查看用于日志记录的记录器名称)也许您应该读取数据库日志并将其移动到顶部,这样做就成功了。我还将all file日志移到了底部,作为catch all日志。现在我得到了我所需要的。谢谢。如果你移到底部的“一网打尽”是这个
,那么你应该删除它,因为它不起任何作用。