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

时间:2021-04-28 22:32:46

标签: asp.net-core logging .net-core serilog

我第一次使用 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 中的配置。

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

1 个答案:

答案 0 :(得分:0)

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

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