【问题标题】:Config nLog .NET Core 3.1, missing debug messages配置 nLog .NET Core 3.1,缺少调试消息
【发布时间】:2021-06-08 15:24:25
【问题描述】:

我查看了 .net 核心中 nLog 的许多配置,一切正常,除了我无法获得要记录的调试消息。如果我写一条信息消息或错误消息,这些工作就很好。所以这似乎是一个日志级别的问题,但我可能会尝试我似乎无法获得足够低的级别来写出调试消息。

我也看过这个:Missing trace\debug logs in ASP.NET Core 3?

Nlog.Web.AspNetCore 4.11 .Net Core 3.1

这是我的配置:

startup.cs 中没有特定的日志记录

程序.sc

  public static void Main(string[] args)
    {
        var logger = NLog.Web.NLogBuilder.ConfigureNLog("nlog.config").GetCurrentClassLogger();
        try
        {
            logger.Debug("init main");
            CreateHostBuilder(args).Build().Run();
        }
        catch (Exception exception)
        {
            //NLog: catch setup errors
            logger.Error(exception, "Stopped program because of exception");
            throw;
        }
        finally
        {
            // Ensure to flush and stop internal timers/threads before application-exit (Avoid segmentation fault on Linux)
            NLog.LogManager.Shutdown();
        }
    }

    public static IHostBuilder CreateHostBuilder(string[] args) =>
        Host.CreateDefaultBuilder(args)
            .ConfigureWebHostDefaults(webBuilder =>
            {
                webBuilder.UseStartup<Startup>();
            })
          .ConfigureLogging(logging =>
          {
              logging.ClearProviders();
              logging.SetMinimumLevel(Microsoft.Extensions.Logging.LogLevel.Trace);
          })
          .UseNLog();  

appsettings.json

  "Logging": {
"LogLevel": {
  "Default": "Trace",
  "Microsoft": "Warning",
  "Microsoft.Hosting.Lifetime": "Information"
}

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"
    throwConfigExceptions="true"
    internalLogLevel="info"
    internalLogFile="c:\temp\Nlog.log">

  <extensions>
    <add assembly="NLog.Web.AspNetCore"/>
  </extensions>
  <targets>
    <target name="database" xsi:type="Database" connectionString="${appsettings:name=ConnectionStrings.applog}" >
      <commandText>
        INSERT INTO [NLog] (
        [ApplicationName],
        [AppUserIdentity],
        [LogDate] ,
        [LogLevel] ,
        [LogSource],
        [LogAssembly] ,
        [LogMessage] ,
        [MachineName] ,
        [DomainUser],
        [CallSite],
        [LogThread] ,
        [LogException]  ,
        [ClientIp]
        )
        VALUES     (
        @ApplicationName,
        @AppUserIdentity,
        @LogDate ,
        @LogLevel ,
        @LogSource,
        @LogAssembly,
        @LogMessage ,
        @MachineName ,
        @DomainUser ,
        @CallSite ,
        @LogThread ,
        @LogException,
        @ClientIp
        );

      </commandText>

      <parameter name="@ApplicationName" layout="${appsettings:name=AppName:default=Missing-Config}" />
      <parameter name="@AppUserIdentity" layout="${aspnet-user-identity}" />
      <parameter name="@LogDate" layout="${date:format=yyyy-MM-dd HH\:mm\:ss.fff}" />
      <parameter name="@LogLevel" layout="${level}" />
      <parameter name="@LogSource" layout="${logger} " />
      <parameter name="@LogAssembly" layout="${assembly-version}" />
      <parameter name="@LogMessage" layout="${message}" />
      <parameter name="@MachineName" layout="${machinename}" />
      <parameter name="@DomainUser" layout="${windows-identity:domain=true}" />
      <parameter name="@CallSite" layout="${callsite}" />
      <parameter name="@LogThread" layout="${threadid}" />
      <parameter name="@LogException" layout="${exception}" />
      <parameter name="@ClientIp" layout="${aspnet-request-ip}" />


      
    </target>
  </targets>

  <rules>
    <logger name="*"  minlevel="Trace" maxlevel="Error" final="true" writeTo="database" />
  </rules>
</nlog>

注入到服务中。此调用不会记录,但如果是 _logger.LogInformation("xx"),它将记录。此 ILogger 参考是 Microsoft.Extensions.Logging.ILogger

     public TaxCalculationService(IUnderwritingRepository repository, ILogger<TaxCalculationService> logger)
        {
            _repository = repository;
            _logger = logger;
        }
        public TaxCalculationResponseDto CalculateTaxes(TaxCalculationRequestDto request)
        {
          
            _logger.LogDebug("calculateTaxes request: " + JsonConvert.SerializeObject(request));

【问题讨论】:

  • 当您查看 Missing Debug/Trace Messages in NetCore 时,您是否记得检查特定于环境的 appsettings.json ? (例如appsettings.Development.jsonappsettings.Production.json
  • 是的,我看过。谢谢

标签: c# nlog asp.net-core-3.1


【解决方案1】:

请尝试升级到NLog.Web.AspNetCore v4.12.0,然后将UseNLog()更改为使用RemoveLoggerFactoryFilter = true,如下所示:

    public static IHostBuilder CreateHostBuilder(string[] args) =>
        Host.CreateDefaultBuilder(args)
            .ConfigureWebHostDefaults(webBuilder =>
            {
                webBuilder.UseStartup<Startup>();
            })
          .ConfigureLogging(logging =>
          {
              logging.ClearProviders();
              logging.SetMinimumLevel(Microsoft.Extensions.Logging.LogLevel.Trace);
          })
          .UseNLog(new NLogAspNetCoreOptions() { RemoveLoggerFactoryFilter = true });

另见:https://github.com/NLog/NLog.Extensions.Logging/pull/482

您可能想要更新 NLog-LoggingRules 以忽略来自 Microsoft-Loggers 的噪音:

<rules>
   <!-- Block output from noisy loggers -->
   <logger name="Microsoft.*" maxlevel="Info" final="true" />
   <logger name="System.Net.Http.*" maxlevel="Info" final="true" />
   
   <!-- Write the good stuff to the databse -->
   <logger name="*"  minlevel="Debug" writeTo="database" />
</rules>

【讨论】:

  • 所以这确实有效,只要我也遵循您提供的链接中的语法。所以在 Startup.cs 我添加了 'services.AddLogging(builder => builder.AddFilter(null, Microsoft.Extensions.Logging.LogLevel.Information));'这似乎有一个缺点。我收到大量 Microsoft.AspNetCore.Mvc* 消息。因此,对于 2 条调试消息,我在日志中收到了 60 条很好的消息。有没有办法限制这些消息,同时仍然收到我的调试消息?
  • @kwcolson98 更新了我关于抑制嘈杂记录器的答案。另见github.com/NLog/NLog/wiki/…
猜你喜欢
  • 2020-07-26
  • 2020-12-01
  • 1970-01-01
  • 2020-08-22
  • 2020-09-16
  • 1970-01-01
  • 1970-01-01
  • 2020-12-01
  • 2020-11-24
相关资源
最近更新 更多