[英]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.