My experience after joining Sentry is that it not only monitors online errors, but also traces the source quickly. Another point is that you can learn about the error handling mechanism, some hidden bugs in the front-end code, and standardize the code by reporting errors
Sentry profile
- Sentry, an open source tool for error monitoring and collection
- Report errors to the server by injecting the SDK into the project to be monitored.
- The server is a data management platform, which can be set up by enterprises themselves or directly use the official website platform.
Access to the steps
- Create projects on the platform
- Inject the SDK
// main.js(ts)
import '@/common/sentry'
// sentry.js
import * as Sentry from '@sentry/browser'
import { Integrations } from '@sentry/tracing'
const environment = DEPLOY_ENVIRONMENT || 'production'
Sentry.init({
dsn: 'https://[email protected]/xxx'.// The unique DSN of the sentry platform creation project can be found after the platform creation
integrations: [new Integrations.BrowserTracing()],
tracesSampleRate: 1.0,
environment,
release: RELEASE_VERSION, // Locate the error in the sourcemap upload version, can be consistent with the sourcemap file version
})
Copy the code
- Upload sourcemap: use it
sentry-webpack-plugin
// Configure only the production environment webpack.prod.conf.js
const SentryPlugin = require('@sentry/webpack-plugin')
const gitSha = require('child_process')
.execSync('git rev-parse HEAD')
.toString()
.trim() // This is the record to get the submitted version
webpackConfig.plugins.push(
new SentryPlugin({
include: './dist'.// Package directory
ignore: ['node_modules'.'build'.'docs'.'jekins'].// configFile: '.. /. Sentryclirc ', // configuration file default ~ /. Sentryclirc, find the root directory
release: process.env.RELEASE_VERSION,
deleteAfterCompile: true,}),)Copy the code
- User-defined error messages are reported
Sentry.captureMessage('Poster avatar failed to generate')
scope.setUser(user)
setTag
...
Copy the code
- Added user crash feedback popover
Sentry.init({
dsn:'https://[email protected]/5706930'.beforeSend(event, hint) {
// Check if it is an exception, and if so, show the report dialog
if (event.exception) {
Sentry.showReportDialog({ eventId: event.event_id });
}
returnevent; }});Copy the code
- Access mailbox 📮 alarm
- Performance monitoring and statistics
- .
Sentry principle
- Window. onError hijacking, listening for unHandledrejection events, listening for the Vue ErrorHandler method
- How to report
- Sentry.init () creates a hub and binds a client and a blank scope to it.
- The client creates events and distributes them to Transport
- Transport handles Ajax reporting requests uniformly
const client = new BrowserClient({
dsn: 'https://<key>@sentry.io/<project>'});const hub = new Hub(client);
hub.configureScope(function(scope) {
scope.setTag("a"."b");
});
hub.addBreadcrumb({ message: "crumb 1" });
hub.captureMessage("test");
try {
a = b;
} catch (e) {
hub.captureException(e);
}
hub.withScope(function(scope) {
hub.addBreadcrumb({ message: "crumb 2" });
hub.captureMessage("test2");
});
Copy the code
@ see ️ ⭐ ️ mp.weixin.qq.com/s?__biz=MzA…
Reference:
- Website ️ ⭐ hub such as definition: develop sentry. Dev/SDK/unified…
- Sentry initialization series: juejin.cn/post/691829…
- What you Don’t know Sentry: mp.weixin.qq.com/s/Yw_g4T9TS…
- Mp.weixin.qq.com/s?__biz=MzA…