[英]Why does 'await' change the thread context in WinForms program.cs
[英]Why does NLog work in controllers and not in Program.cs?
我已将 NLog 添加到我的 MVC Core 2.2 项目中,除了应用程序启动日志记录外,一切正常。 日志在控制器中写得很好,但在 Program.cs 中写得不好。 这是我的主要方法,所有 NLog 内容均取自 NLog 文档:
public static void Main(string[] args)
{
// NLog: setup the logger first to catch all errors
var logger = NLogBuilder.ConfigureNLog("nlog.config").GetCurrentClassLogger();
try
{
logger.Info("Starting app");
CreateWebHostBuilder(args).Build().Run();
}
catch (Exception ex)
{
// NLog: catch setup errors
logger.Error(ex, "App failed to start");
throw;
}
finally
{
// Ensure to flush and stop internal timers/threads before application-exit (Avoid segmentation fault on Linux)
NLog.LogManager.Shutdown();
}
}
NLog 自己的日志显示如下:
错误 已引发错误。 异常:System.ArgumentException:路径不是合法形式。 在 NLog.Targets.FileTarget.Write(LogEventInfo logEvent) 在 NLog.Targets.Target.Write(AsyncLogEventInfo logEvent)
这很奇怪,因为日志是在我定义的文件路径中正确写入的。
这是我的 nlog.config:
<?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="c:\temp\nlog.log"
throwConfigExceptions="true">
<!-- enable asp.net core layout renderers -->
<extensions>
<add assembly="NLog.Web.AspNetCore"/>
</extensions>
<variable name="logFilePath" value="${configsetting:name=Logging.LogFilePath}"/>
<targets>
<target xsi:type="File"
name="PortailUsagersCore"
fileName="${logFilePath}"
layout="${longdate}|${event-properties:item=EventId_Id}|${uppercase:${level}}|${logger}|${message} ${exception:format=tostring}|url: ${aspnet-request-url}|controller: ${aspnet-mvc-controller}|action: ${aspnet-mvc-action}"
maxArchiveFiles="4"
archiveNumbering="Rolling"
archiveAboveSize="2097152" />
</targets>
<rules>
<logger name="*" writeTo="PortailUsagersCore" />
</rules>
</nlog>
LogFilePath 在日志记录部分的 appsettings.json 和 appsettings.development.json 中定义:
"Logging": {
"LogFilePath": "C:\\Logs\\Portail\\PortailUsagersCore.log",
"IncludeScopes": false,
"LogLevel": {
"Default": "Trace",
"Microsoft": "Information"
}
}
感谢 RolfKristensen 的建议,我设法使它工作。 现在在 NLog 初始化之前读取 Appsettings,因此 NLog 现在能够读取其中的文件路径。 我使用 NLog.GlobalDiagnosticsContext 在 NLog.config 中设置 filePath。
string env = Environment.GetEnvironmentVariable("ASPNETCORE_ENVIRONMENT");
// Load config file to read LogFilePath
var config = new ConfigurationBuilder()
.AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
.AddJsonFile($"appsettings.{env}.json", optional: true, reloadOnChange: true)
.Build();
// LogFilePath is read in nlog.config
NLog.GlobalDiagnosticsContext.Set("LogFilePath", config["Logging:LogFilePath"]);
// NLog: setup the logger first to catch all errors
var logger = NLogBuilder.ConfigureNLog("nlog.config").GetCurrentClassLogger();
在我的 NLog.config 中,我以这种方式使用它:
<variable name="logFilePath" value="${gdc:item=LogFilePath}"/>
<targets>
<target xsi:type="File"
name="PortailUsagersCore"
fileName="${logFilePath}"
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.