原来这个问题与
NLog
ASP.NET 日志系统无关。日志配置正确,但Debug
由于配置错误,构建服务器正在将构建发布到生产环境。
2.1.401
我正在尝试在我的 ASP.NET Core 2.0 (SDK ) 项目中设置第三方记录器。到目前为止,我已经尝试过Serilog
和NLog
. 但是我对两者都有同样的问题。总结一下这个问题,
- 当我运行应用程序时它按预期工作
dotnet run
(即在Development
环境中) dotnet MyApplication.dll
但是当我运行二进制文件时(即在Production
环境中)它不会。- 我的文件中没有在环境
"Logging"
部分定义任何内容。Development
appsettings.Development.json
下面描述的问题是针对NLog
. 我已经尝试SeriLog
并遇到了同样的问题。
这是来自的相关部分Program.cs
public static IWebHost BuildWebHost(string[] args) =>
WebHost.CreateDefaultBuilder(args)
.UseApplicationInsights()
.UseStartup<Startup>()
.ConfigureLogging((env, logging) =>
{
logging.ClearProviders();
logging.SetMinimumLevel(Microsoft.Extensions.Logging.LogLevel.Trace);
})
.UseNLog()
.Build();
注意我已经清除了所有提供程序并添加NLog
了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="error"
internalLogFile="./internal-nlog.txt">
<extensions>
<add assembly="NLog.Web.AspNetCore"/>
</extensions>
<targets>
<target name="Console"
xsi:type="Console"
layout="${longdate}|${event-properties:item=EventId_Id}|${uppercase:${level}}|${logger}|${message} ${exception:format=tostring}|url: ${aspnet-request-url}|action: ${aspnet-mvc-action}" />
</targets>
<rules>
<logger name="*" minlevel="Trace" writeTo="Console" />
</rules>
</nlog>
在Development
模式下运行时,我看到的日志完全符合我的预期
$ dotnet run
Using launch settings from .. /Properties/launchSettings.json...
2018-09-16 19:04:39.7585||DEBUG|My.WebApp.Program|init main |url: |action:
Hosting environment: Development
Content root path: /Users/ ...
Now listening on: http://localhost:61638
Application started. Press Ctrl+C to shut down.
2018-09-16 19:04:46.5405|1|INFO|Microsoft.AspNetCore.Hosting.Internal.WebHost|Request starting HTTP/1.1 GET http://localhost:61638/api/_doc |url: http://localhost/api/_doc|action:
2018-09-16 19:04:46.7381|1|INFO|Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker|Executing action method My.WebApp.RestApi.Doc (My.WebApp) with arguments ((null)) - ModelState is Valid |url: http://localhost/api/_doc|action: Doc
但是,当我在环境中运行应用程序时Production
,控制台输出看起来好像我没有NLog
安装并且我没有清除默认提供程序。
dotnet .\My.WebApp.dll
Hosting environment: Production
Content root path: C:\inetpub\wwwroot\myapp\wwwroot
Now listening on: http://localhost:5000
Application started. Press Ctrl+C to shut down.
info: Microsoft.AspNetCore.Hosting.Internal.WebHost[1]
Request starting HTTP/1.1 GET http://localhost:5000/
info: Microsoft.AspNetCore.Mvc.Internal.ControllerActionInvoker[1]
Executing action method My.WebApp.Controllers.HomeController.Index (My.WebApp) with arguments ((null)) - ModelState is Valid
请注意这些行以info:
? 当您使用定义的默认日志记录设置时,这些是标准控制台日志记录格式Microsoft.Extensions.Logging
。但我肯定Console
通过调用文件清除了提供logging.ClearProviders();
程序Program.cs
。
谢谢你的帮助。