如何使用 sentry v5 全局忽略错误以减少噪音
How to globally ignore errors with sentry v5 to reduce noise
使用已弃用的客户端 Raven,您可以忽略麻烦的错误:
Raven.config('your-dsn', {
ignoreErrors: [
'Can\'t execute code from freed script',
/SecurityError\: DOM Exception 18$/
]
}).install();
我发现新客户端的唯一方法是使用 before-send
挂钩:
https://docs.sentry.io/error-reporting/configuration/filtering/?platform=browser#before-send
import * as Sentry from '@sentry/browser';
init({
beforeSend(event, hint) {
const { message } = hint.originalException;
if (message && message.match(/database unavailable/i)) {
return null;
}
return event;
}
});
我搜索了整个文档,但没有找到忽略错误的全局方法。
似乎有一个 ignoreErrors
配置选项。它记录在他们的示例应用程序中:
普通 JS:
process.on('unhandledRejection', (reason, promise) => {
//console.log('(Custom message) Unhandled Rejection found at:', reason.stack, reason.caputureStackTrace);
console.log('Unhandled Rejection at: Promise', promise, 'reason:', reason, reason.constructor.name);
});
我猜你的正则表达式不匹配,尝试:/SecurityError\: DOM Exception 18$/
而不是 /SecurityError\: DOM Exception 18$/
,注意 \
简单,我在 nuxt.config.js
中将此配置用于 nuxtjs 应用程序
sentry: {
disabled: process.env.APP_ENV === 'development',
dsn: 'xxxx'
maxBreadcrumbs: 50,
config: {
environment: process.env.APP_ENV,
debug: process.env.APP_ENV === 'development',
release: '1.0.0',
beforeSend: (event, hint) => {
// see all errors, what you wants.
// using console.log(hint.originalException)
// for example, not send when error code 404 when using axios
const { response } = hint.originalException
if (response && response.status && response.status === 404) {
return null
}
return event
}
}
},
使用已弃用的客户端 Raven,您可以忽略麻烦的错误:
Raven.config('your-dsn', {
ignoreErrors: [
'Can\'t execute code from freed script',
/SecurityError\: DOM Exception 18$/
]
}).install();
我发现新客户端的唯一方法是使用 before-send
挂钩:
https://docs.sentry.io/error-reporting/configuration/filtering/?platform=browser#before-send
import * as Sentry from '@sentry/browser';
init({
beforeSend(event, hint) {
const { message } = hint.originalException;
if (message && message.match(/database unavailable/i)) {
return null;
}
return event;
}
});
我搜索了整个文档,但没有找到忽略错误的全局方法。
似乎有一个 ignoreErrors
配置选项。它记录在他们的示例应用程序中:
普通 JS:
process.on('unhandledRejection', (reason, promise) => {
//console.log('(Custom message) Unhandled Rejection found at:', reason.stack, reason.caputureStackTrace);
console.log('Unhandled Rejection at: Promise', promise, 'reason:', reason, reason.constructor.name);
});
我猜你的正则表达式不匹配,尝试:/SecurityError\: DOM Exception 18$/
而不是 /SecurityError\: DOM Exception 18$/
,注意 \
简单,我在 nuxt.config.js
中将此配置用于 nuxtjs 应用程序 sentry: {
disabled: process.env.APP_ENV === 'development',
dsn: 'xxxx'
maxBreadcrumbs: 50,
config: {
environment: process.env.APP_ENV,
debug: process.env.APP_ENV === 'development',
release: '1.0.0',
beforeSend: (event, hint) => {
// see all errors, what you wants.
// using console.log(hint.originalException)
// for example, not send when error code 404 when using axios
const { response } = hint.originalException
if (response && response.status && response.status === 404) {
return null
}
return event
}
}
},