Ведение журнала не отображается в файле журнала при использовании nlog - PullRequest
0 голосов
/ 27 января 2020

Я использую 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"
    }
  },
...