Я использую NLog с. net Core 3.1. Я пытаюсь распечатать оператор отладки в моем контроллере, где ILogger вводится следующим образом:
public MyController(ILogger<MyController> logger) {
this.logger = logger;
}
[HttpGet)]
public ActionResult<List<MyObject>> GetObjects()
{
logger.LogDebug("helloworld");
}
Когда я отлаживаю, оператор работает нормально, но в файле журнала ничего не появляется. Вот другие соответствующие файлы. Что-то отсутствует или неверно в конфигурации?
Внутри program.cs
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup<Startup>();
})
.ConfigureLogging(logging =>
{
logging.ClearProviders();
logging.SetMinimumLevel(LogLevel.Debug);
})
.UseNLog(); // NLog: Setup NLog for Dependency injection
Внутри nlog.config
<targets>
<!-- write logs to file -->
<target xsi:type="File" name="allfile" fileName="c:\logs\nlog-all-${shortdate}.log"
layout="${callsite} -${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="c:\logs\nlog-own-${shortdate}.log"
layout="${callsite} -${longdate}|${event-properties:item=EventId_Id}|${uppercase:${level}}|${logger}|${message} ${exception:format=tostring}|url: ${aspnet-request-url}|action: ${aspnet-mvc-action}" />
</targets>
<!--rules to map from logger name to target-->
<rules>
<logger name="*" minlevel="Debug" writeTo="allfile" />
</rules>
в настройках приложения. json
"Logging": {
"IncludeScopes": false,
"LogLevel": {
"Default": "Trace",
"Microsoft": "Warning",
"Microsoft.Hosting.Lifetime": "Information"
}
},