我第一次使用 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 中的配置。
我通过将日志添加到构造函数中并在方法上调用它来消耗日志,这似乎也不错。
答案 0 :(得分:0)
根据您的描述和设置,我发现您的 Serilog MinimumLevel 是错误而非信息。
如果您记录信息,它不会登录到数据库中。您应该改用日志错误。