繁体   English   中英

在 .net 内核上使用 Serilog 进行日志记录

[英]Logging with Serilog on .net core

我第一次使用 Serilog,我阅读了一些教程,但它没有写在 DB 上

这是我编写配置的 Program.cs 文件:

public class Program
{
    public async static Task Main(string[] args)
    {
        var host = CreateHostBuilder(args).Build();
        await host.RunAsync();
    }



    public static IHostBuilder CreateHostBuilder(string[] args)
    {
        var configSettings = new ConfigurationBuilder()
            .AddJsonFile("appsettings.json")
            .Build();

        Log.Logger = new Serilog.LoggerConfiguration()
            .ReadFrom.Configuration(configSettings)
            .CreateLogger();

        return Host.CreateDefaultBuilder(args)
        .ConfigureAppConfiguration(config =>
        {
            config.AddConfiguration(configSettings);
        })
        .ConfigureLogging(logging =>
        {
            logging.AddSerilog();
        })
        .ConfigureWebHostDefaults(webBuilder =>
        {
            webBuilder.UseStartup<Startup>();
        });

    }
}

}

执行时没有问题,并且它在丢失时也创建了表,但它没有插入日志。

"Serilog.Extensions.Logging": "1.0.0",
  "Serilog": {
    "MinimumLevel": "Error",
    "WriteTo": [
      {
        "Name": "MSSqlServer",
        "Args": {
          "connectionString": constr,
          "tableName": "Logs",
          "autoCreateSqlTable": true
        }
      }
    ]
  }

这是 appjson 中的配置。

我通过在构造函数中添加日志并在方法上调用它来消耗日志,这似乎也可以。

根据您的描述和设置,我发现您的 Serilog MinimumLevel 是错误而不是信息。

如果您记录信息,它将不会登录到数据库。 您应该改用日志错误。

暂无
暂无

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

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