appsettings.json 中的哨兵配置与 .Net Core 3 控制台应用程序中的 Serilog



我使用以下代码在我的 .Net Core 控制台应用程序中使用Serilog配置Sentry

return new LoggerConfiguration()
.MinimumLevel.Debug()
.WriteTo.Sentry(o =>
{
o.MinimumBreadcrumbLevel = LogEventLevel.Error;
o.MinimumEventLevel = LogEventLevel.Error;
o.Dsn = new Dsn(configuration.GetValue<string>("Sentry:Dsn"));
o.Debug = false;
o.AttachStacktrace = true;
o.SendDefaultPii = true;
})
.CreateLogger();

现在我想在appsettings.json文件中移动所有这些配置,因为我需要在开发环境和生产中具有不同的配置:

例:

"Sentry": {
"Dsn": "<dsn>",
"IncludeRequestPayload": true,
"IncludeActivityData": true,
"Debug": false,
"DiagnosticsLevel": "Debug",
"MinimumBreadcrumbLevel": "Debug",
"MinimumEventLevel": "Warning"
},

是否可以从那里读取整个配置?

更新

我在控制台应用程序中尝试以下配置:

static void Main(string[] args)
{
using (SentrySdk.Init("<dsn>"))
{
// my code
}
...
serviceCollection.AddSingleton<ILogger>(s =>
{
return new LoggerConfiguration()
.ReadFrom.Configuration(configuration)
.CreateLogger();
});

应用设置:

"Serilog": {
"Using": [ "Serilog.Sinks.Console", "Serilog.Sinks.Sentry" ],
"MinimumLevel": {
"Default": "Information",
"Override": {
"Microsoft": "Warning",
"System": "Warning",
"Sentry": "Information"
}
},
"Enrich": [ "FromLogContext" ],
"WriteTo": [
{
"Name": "Console"
},
{
"Name": "Sentry",
"Args": {
"Dsn": "<dsn>",
"MinimumBreadcrumbLevel": "Info",
"MinimumEventLevel": "Info",
"AttachStackTrace": true, 
"Debug": true,
"DiagnosticsLevel": "Info"
}
}
]

但是SentrySdk.Init("<dsn>")需要一个DSN,它不会从应用程序设置中读取它!

是这样吗?

Serilog不知道 ASP.NET Core配置。至少以一种将配置对象的特定部分绑定到其扩展的方式。

如果您使用的是 ASP.NET Core,我假设您也在使用Sentry.AspNetCore.建议你这样做。在这种情况下,您还需要将配置传递给它。

NuGetTrends是一个开源项目,使用Serilog和 ASP.NET Core,同时使用appsettings.json文件进行配置。

这是程序.cs设置哨兵,Serilog和 ASP.NET 核心。

请注意,您提到的配置(以Sentry作为密钥(将由Sentry.AspNetCore获取,但不会由Sentry.Serilog(与 ASP.NET Core分离(获取。

您可以配置后者,这是一个普通的 Serilog 接收器,如下所示:

"Serilog": {
"MinimumLevel": {
"Default": "Information",
"Override": {
"Microsoft": "Warning",
"System": "Warning",
"Sentry": "Information"
}
},
"WriteTo": [
{
"Name": "Sentry",
"Args": {
"MinimumBreadcrumbLevel": "Debug",
"MinimumEventLevel": "Warning"
}
}
],
"Enrich": [ "FromLogContext", "WithMachineName" ]
}

我建议将DSN和其他设置保留在Sentry键上,这使得 ASP.NET 核心初始化SDK,它还将利用Serilog集成。

相关内容

最新更新