gpt4 book ai didi

c# - appsettings.json 中的 Sentry 配置与 .Net Core 3 控制台应用程序中的 Serilog

转载 作者:行者123 更新时间:2023-12-04 10:38:18 29 4
gpt4 key购买 nike

我正在使用以下代码来配置SentrySerilog在我的 .Net Core Console 应用程序中:

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,它不会从 appsettings 中读取它!

是这样吗?

最佳答案

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

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

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

Here's the Program.cs setting up Sentry, Serilog and ASP.NET Core.

请注意,您提到的配置(以 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 key ,它使 ASP.NET Core 初始化 SDK,它还将利用 Serilog 集成。

关于c# - appsettings.json 中的 Sentry 配置与 .Net Core 3 控制台应用程序中的 Serilog,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60057527/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com