preface
What are some of the ways that front-end projects currently find bugs?
- The test shows you. Disadvantages: browser version, too many mobile phone models, compatibility problems are difficult to measure completely. In addition, the process of some projects is very long and complicated, so the test students cannot ensure that 100% cases can be covered every time.
- Colleague Code Review. Disadvantages: The disadvantage of this is that it costs a lot of time, and most of the time, code review only finds code style problems, and other students do not have time to read the logic and business in depth.
- Customer complaint feedback after wiring. Disadvantages: It is very difficult to reproduce the problem because of the variety of models and browsers. In addition, most users do not understand professional terms, inaccurate expression of problems, high communication costs, which lead to very low efficiency in solving problems.
In order to solve the current situation in the project development and management process: it is difficult to test all cases before launch, difficult to reproduce problems after launch, and high communication cost, sentry was added to my project.
What is a Sentry?
Sentry, the Chinese translation is sentry. It is an error monitoring and collection tool. Sentry will immediately inform the developer of the error and help us record the error.
Using Sentry involves combining two parts, the client side and the server side. The client is the project you need to listen to. The server is a data management platform that displays collected error messages and project information. And support project management, group management, email alarm and other functions.
You can build your own server platform or use the official Sentry platform.
In addition, the sentry is very strong in support for multiple languages and frameworks (docs. Sentry. IO/platforms /) here I only studied the front-end how to use it. Other languages and frameworks, as well as server construction are not involved for the time being.
Now that we know what a sentry is, how do we use it?
The Sentry access
New project
First, the new project is completed on the Sentry server platform. Sentry. IO /. After creating a new project, a DSN string is generated. The DSN is the key that links the project we want to report to the Sentry server. Every time we create a new project on the Sentry server, we get a unique DSN. DSN needs to be configured to the project during project initialization. In this way, when the client reports an error, the server can catch the error in the corresponding project.
Installing the SDK
The SDK was installed in exactly the same way as our normal project references third-party packages. CDN import and NPM package injection are available, and the configurations of the two import modes are the same.
<script src="https://browser.sentry-cdn.com/5.6.1/bundle.min.js" integrity="sha384-pGTFmbQfua2KiaV2+ZLlfowPdd5VMT2xU4zCBcuJr7TVQozMO+I1FmPuVHY3u8KB" crossorigin="anonymous"></script>
Copy the code
npm install @sentry/browser
Copy the code
configuration
// When using npm, import Sentry
import * as Sentry from '@sentry/browser';
Sentry.init({ dsn: 'https://[email protected]/1509915' });
Copy the code
Note: If you are a Vue project, do not use Sentry in your development environment. Since Vue projects use Sentry, @Sentry/Integrations needs to be configured. @Sentry/Integrations is implemented through custom Vue errorHandler hooks, which will stop activating Vue raw logError. Causes errors in Vue components not to be printed in the console. So vUE projects do not use Sentry in the development environment.
Here I add, why does the Vue project need to configure the Sentry integrator? The Sentry integrator in question is the SDK used to enhance the Sentry Api. The VUE project configures it to capture the component name and props state that caused the error.
In addition, Integrations.vue has the following configuration options:
1. Vue: Optional, if you do not pass in, window.Vue must exist;
2. AttachProps: This parameter is optional. The default value is true. If set to false, Sentry disallows sending the active component names and props status of all Vue components.
3. LogErrors: Optional. The default value is false. If set to true, Sentry calls the logError function of the original Vue.
import Vue from 'vue'
import * as Sentry from '@sentry/browser'
import * as Integrations from '@sentry/integrations'
Sentry.init({
release: VERSION,
dsn: 'https://[email protected]/1509915'.integrations: [
new Integrations.Vue({
Vue,
attachProps: true // Whether to report components props})]})Copy the code
Advanced usage
Now that we know how to plug sentry into the project, sentry can already report errors for us. By default, sentry reports any uncaught errors (including window.error and promise exceptions) thrown by the page. However, Sentry also provides us with some more advanced features. Next, let’s look at sentry advanced usage.
Commonly used functions
- Proactively catch and report errors. There are two methods for proactively reporting information: One is to report text information directly, and the parameter is a string. The other is to report an error object, which takes an error object or a class object.
try {
aFunctionThatMightFail();
} catch (error) {
// Report an error object
Sentry.captureException(error);
}
// Report a text message
Sentry.captureMessage('Something went wrong');
Copy the code
- Enrich BUG context data.
Sentry provides context information with five users, tags, level, Fingerprint, and Extra data. We can set this information on the scope. There are two ways to set this: Enriching BUG context data is simply adding custom information to the reported event.
Sentry provides customizable context information such as User, Tags, level, Fingerprint, and Extra Data.
This information can be defined by setting it on scope. There are two Settings:
One is sentry.configScope, which sets information to the sentry global scope. The information set in this mode is carried by all subsequent reported events.
Another approach, sentry.withScope, sets a temporary message to the current event. This can be interpreted as a one-off setting of information. Data set in this way only takes effect for the current event. This is used when we want to set information individually for an event without affecting the “global” scope.
Here’s how to add context information:
// Set user information:Scope. SetUser ({" email ":" [email protected] "})// Define a label for an event:Scope.settags ({' API ', 'API/list/get'})// Set the severity of the event:Scope. SetLevel (" error ")// Set the event grouping rule:
scope.setFingerprint(['{{ default }}', url])
// Set additional data:Scope. SetExtra (' data ', {request: { a: 1.b: 2 })
Copy the code
You can use scope.setUser to set the user id, username, IP address, and email.
Use scope.setTags to define different key/value pairs for events. After the event is reported, when we look in the background, the filter option will have additional options, which are set by setTags.
SetLevel is used to set the severity of the event. The parameters are fatal, ERROR, warning, INFO, and DEBUG. Fatal: fatal, error stands for error. All reported events are error by default.
Use scope.setFingerprint to customize the grouping rules for events. Sentry has a default grouping policy. But sometimes that doesn’t meet our needs. For example, sentry will group all UnhandledRejection together, but in fact we want to group them more carefully, such as by interface URL. SetFingerprint ([‘ {{default}} ‘, URL])).
Sentry.setExtra can set additional data, such as logging ajax request parameters, return values, header information, and so on
- Upload the SourceMap file.
One of Sentry’s strengths over other error monitoring platforms is its support for Sourcemap. As long as we upload the Sourcemap file to the server as well, we can see the source code on the Sentry platform and quickly locate errors.
We mentioned earlier that we need to upload the souceMap file to the server, but this would expose our source files to the client, which is very insecure. In addition, sentry parsing requires the sourcemap file to be retrieved from another server, which also adds overhead between servers.
Therefore, the official recommendation is to upload Sourcemap to the Sentry server.
There are three ways to upload Sourcemap to the Sentry server.
The first is to use the WebPack plug-in provided by Sentry to upload the project automatically when it is packaged. This is the most convenient of the three methods, because you only need to add the relevant configuration information to the WebPack configuration. So most people in the industry use this way.
The second is to use the upload script provided by Sentry, Sentry-CLI upload.
The third method is to directly call the Sentry API to upload, which has many configuration parameters and is troublesome.
Comprehensive comparison of the above 3 upload methods, I did not hesitate to choose the first, upload, error can be located to the source, seems to be very smooth.
However, we found a problem soon after we used it. Our project was slow to go online.
It turns out that sentry provides a synchronous upload method for sourcemap, which causes a slow launch. So, we can optimize it for asynchronous upload.
other
- Capture user feedback on crashes.
- Add filter events and custom logic to hooks such as beforeSend.
- AddBreadcrumb adds an action record, etc.
Sentry.init({
dsn: 'https://[email protected]/1509915',
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
Sentry also introduces the concept of bread crumbs. The breadcrumbs in sentry are simply logs and events that sentry automatically logs. Examples include browser URL changes, Ajax requests, previous error events, etc. Recording this information provides context for the current error, recreates the steps that led to the error, and provides key information for replaying and debugging the error. Sentry also provides a custom API for adding and closing breadcrumbs. I won’t go into that because it’s not very common.
Today is mainly about the role of sentry and use methods, to talk about these. To sum up: Sentry is an out-of-the-box, compatible, powerful, and ecosphere perfect monitoring tool. You deserve it 😏.