One, foreword
If Spa or Mpa projects introduce Sentry, it will be easier, but if it is a micro front-end architecture or Monorepo projects introduce Sentry, it needs some skill, otherwise the source map between multiple projects will be troublesome.
Let’s take a look at how simple projects introduce the Sentry service. Let’s take a look at how simple error messages are captured and presented to the user.
Take a look at the picture below:
To summarize, there are three steps
- The browser generates an error, which is then caught by the Sentry client
- Upload to the Sentry server
- The server resolves the error, locates the error through the Source map, and finally presents the user with the following information
This is the sentry introduction method for normal projects, but not for Monorepo. In some large application services, there are many projects in one domain, and it would be too cumbersome to create a Sentry Project for each project.
Here’s a concrete example:
For example, in a www.xxx.com domain, there are www.xxx.com/project-a/x.html and www.xxx.com/project-b/x.html projects, because it is in the same domain, if the traditional Sentry deployment mode is used, This means that each project needs to create a project, which is a hassle.
Is there a way to manage Monorepo projects in the same domain with a Sentry project? Read the sentry-CLI documentation carefully and it should be ok.
Second, implementation scheme
The key is how to associate the error with sourcemap. Only by associating the error with sourcemap can the errors collected by Sentry be meaningful.
There are two important parameters in the sentry-CLI document, release and urlPrefix.
- Release is responsible for the release number of each release, and this is how the client and server relate to each other
- UrlPrefix can be used to solve the Monorepo project deployment problem under a Sentry project
Through the figure above, the process has been combed again
- Generated by the custom release information for each of the project, code paths: script/genBuildRelease js, the generated code is as follows
- Based on the sentry – cli release uploaded to the server, the code path: script/uploadSourceMap. Js
- In the build code, to release the information into the source code, the code path: libs/common/SRC/lib/sentry. Ts
- When an error is caught, it is sent to the server via release
- After the Sentry Server collects the information, it associates the sourcemAP with release to resolve the corresponding error
This is the end of Monorepo’s sentry deployment scheme
Third, making the demo
If you still feel a bit confused, the above Nx sentry deployment code has been uploaded to Github. If you are interested, you can download it and run down
Making the demo address