繁体   English   中英

Serilog 不记录信息日志

[英]Serilog not logging information logs

在我的 .NET Core 2.1 项目中,我安装了Serilog ,但由于某种原因它不会记录信息事件。 不过,它会记录错误事件。

在我的 appSettings 中,我有:

    "Serilog": {
        "MinimumLevel": {
          "Default": "Information",
          "Override": {
            "Microsoft": "Fatal",
            "System": "Fatal"
          }
        },
        "WriteTo": [
          {
            "Name": "File",
            "Args": {
              "restrictedToMinimumLevel": "Information",
              "path": "D:\\Web\\098_VDSNet4\\Logs\\API.AdminPortal\\.txt",
              "rollingInterval": "Day"
            }
          }
        ]
      }

在我的 Startup.cs 中,我有:

                Log.Logger = new LoggerConfiguration()
                    .MinimumLevel.Verbose()
                    .ReadFrom.Configuration(Configuration)
                    .CreateLogger();

                services.AddLogging(logging =>
                    logging.AddSerilog(dispose: true)
                );

在代码中我有:

            public IActionResult Post(Address address)
            {
                string functionName = "AddressController:Post";

                try
                {
                    logger.LogInformation($"{functionName}");

                    // TOOD Additional Address validation
                    addressRepository.Add(address);
                    addressRepository.Save();

                    return Ok(address);
                }
                catch(Exception ex)
                {
                    logger.LogError(ex, $"{functionName}: There was an error creating the address");
                    return BadRequest();
                }

            }

logger.LogInformation (我也尝试过logger.LogDebug ,这也不起作用)不输出任何内容。 但是logger.LogError确实记录了正确的错误。

我曾尝试将默认级别更改为 Verbose 以查看是否会启动它,但我似乎无法将 Error 以下的任何内容输出到日志文件。

您必须将ILogger<HomeController>接口注入HomeController构造函数。

    private readonly Microsoft.Extensions.Logging.ILogger _log;

    public HomeController(ILogger<HomeController> logger)
    {
        _log = logger;
    }

你必须告诉asp.net core从哪里读取配置(在Program.cs添加):

public static IConfiguration Configuration { get; } = new ConfigurationBuilder()
            .SetBasePath(Directory.GetCurrentDirectory())
            .AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
            .AddJsonFile($"appsettings.{Environment.GetEnvironmentVariable("ASPNETCORE_ENVIRONMENT") ?? "Production"}.json", optional: true)
            .Build();

在 Program.cs 添加UseSerilog

    public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
        WebHost.CreateDefaultBuilder(args)
            .UseStartup<Startup>()
            .UseSerilog();

结果:

错误和信息的结果

通过构造函数将您的日志注入控制器以使用它。

using Serilog;

public class MyController : Controller
{
    private readonly ILogger _log;

    public MyController(ILogger log)
    {            
        _log = log;
    }

    public IActionResult Post(Address address)
    {
        //Make sure you are using the variable you set up in this controller
        _log.Information**("Hello World!");
    }
}

确保您使用的是在构造函数中分配的控制器中创建的变量。 不要使用 Logger.LogInformation。 使用 _log.Information。 您正在注入的记录器是您正在配置的记录器。 Logger.LogInformation 使用的是 Microsoft 记录器,而不是您设置的 serlilog。 Serilog 将是 .Information 而不是 .LogInformation。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM