我使用以下代码在我的 .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集成。