我尝试使用sentrydotnet.aspnetcore将未处理的异常记录到sentry。
我的startup.cs已经
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc();
var dsn = "[dsn]";
services.AddSentryDotNet(
new SentryClient(
dsn,
new SentryEventDefaults(
environment: "test",
release: typeof(Startup).Assembly.GetName().Version.ToString(3),
logger: "coremvcapp")));
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
app.UseStaticFiles();
app.UseMvc(routes =>
{
routes.MapRoute(
name: "default",
template: "{controller=Home}/{action=Index}/{id?}");
});
app.UseSentryDotNet(new SentryDotNetOptions { CaptureRequestBody = true });
//app.Run(async context => { await DoSomethingAsync(context); });
}
有一个示例调用来调用成功登录到Sentry的中间件。
private static async Task DoSomethingAsync(HttpContext context)
{
if (context.Request.Path.HasValue && context.Request.Path.Value.Contains("error"))
{
throw new InvalidOperationException("Boom");
}
await context.Response.WriteAsync("some stuff");
}
问题是,如果在控制器操作中引发异常,则不会调用中间件。
public IActionResult LogError()
{
throw new Exception("mvc error");
}
我为中间件的invoke方法设置了一个断点,当操作中的异常被抛出时,它不会被击中。
中间件有这个调用方法
public async Task Invoke(HttpContext context)
{
try
{
await _next.Invoke(context);
}
catch (Exception e) when (_client != null)
{
// log stuff
throw;
}
}
我看到它在应用程序启动时被初始化
public SentryDotNetMiddleware(RequestDelegate next, ISentryClient client, SentryDotNetOptions options)
{
_next = next;
_client = client;
_options = options;
}
是否缺少某些内容,以便调用中间件的invoke方法来执行操作中未处理的过度操作?
编辑
对于我来说,Sentry Sentry.aspnetcore提供的实现是现成的。我试过的所有其他包装还有其他小问题。