preface

Front-end monitoring has been a very important part of the development and production, because the original project monitoring mechanism in the group is not universal and the new project has not yet perfect front-end monitoring, so I want to study and build a feasible front-end monitoring scheme. So there is this article, small companies to save costs, charging monitoring scheme is not considered, the use of free scheme is the most mainstream sentry ~ 😄

This article is recommended to be read together with the following article. This article preliminarily touches on the core technologies of front-end monitoring solutions. The next article is the detailed usage details and case practice of monitoring solutions

Front-end Monitoring Sentry – Next. Js Project monitoring practices

[note ️] : If you have successfully set up Sentry locally (server), please click the close button in the upper left corner (upper right corner), this article will waste your time ~

Docker

I can’t tell you anything about Docker knowledge while writing. If you want to know more, you can refer to more articles in the community. I will also recommend some articles at the end. And Docker is really popular on the front end

Step 1: Install Docker

I is according to the official website tutorial, registered accounts, step by step came along, the official introduction to provide is a personal guide, so here, not much say what, as long as you according to the official guidelines, achieved as shown in the following steps, it means we level has been consistent, don’t know why, anyway I am run up (small head, hum ~ 😄) :

Step 2: Deploy node.js applications using Docker

Back to the essence, learning Docker is to conduct Sentry monitoring, and the monitoring content is the front-end application, I take the Next. Js project as an example, so it is essentially a Node.js application.

It could be any type of application.

Dockerfile

The core of Docker deployment application is Dockerfile file, basically all configuration items are written here, the relevant Docker deployment command will find the file to execute the corresponding command. Here, I use the next-antd-Scaffold scaffold to demonstrate a Docker locally deployed Node.js application.

# DockerfileFROM the node: 8.14 As a builder# Base dependencies
LABEL maintainer="luffyZh"   # Label - Project maintainer
COPY . .                     Copy all files to the root directory of the container. This can be adjusted according to preference
RUN yarn install             # install dependencies
CMD yarn start               The command to run in the container environment

Copy the code

Build the mirror

# command to build the imageDocker build-t [imageName]:[imageVersion].Copy the code

The building process is as shown in the figure above, EMM, don’t worry, the red part is the warning warning inside the scaffolding, it is not wrong, I also made a jump in the first build, hope docker can change the color of warning 😄. If successfully, the build is successful. Use Docker Images to view the list of local images:

As you can see, the image you just built appears in the list.

Run locally

# run commandDocker runit -p 8080:3006 Luffyzh/Next-ANTD-Scaffold: V1 -I: Runs in interactive mode and is used with -t. -t: reassigns a pseudo-input terminal to the container. It is usually used together with -i. -p: specifies the port mapping. The format is as follows: Host (host) port: container port. In this case, port 3006 of the container is mapped to port 8080 of the host-d-it exits the console with CTRL + C and the container is closed. The application is closed. If you want to run in the background, change -it-dThe commandCopy the code

The program output looks like this, but remember!! The address we want to visit is http://localhost:8080 instead of http://localhost:3006, because we have carried out port mapping, and the output of the console is the output of the pseudo terminal started in the Docker container, as shown in the figure below:

Yarn Install + YARN Start is started in the development environment. Yarn Install + YARN Build + YARN Prod is used in the production environment. Our startup command is CMD, so what about the previous two commands? All right, check the files

The RUN command can be executed from top to bottom, so modify the Dockerfile

# DockerfileFROM node:8.14 As Builder LABEL Maintainer ="luffyZh"
COPY . .
RUN yarn install
RUN yarn build
CMD yarn prod
Copy the code

Related questions small inquiry

In the above three images, I executed three docker run commands:

# first, no port numberResult: the container successfully started the project, but the local browser can not access, 5999 or any other port, that is, need to set -p [host port]:[container port] mapping# 2, mapping container wrong portResult: The container successfully started the project on port 5999, while mapping port 5888 to local 8080, accessing local 8080 did not start the service# 3, map correctlyResult: 5999 -> local 8080 is successfully started in the container, and the program runs normally after startup.Copy the code

In other words, the -p command is required to map the host port to the container so that it can be accessed externally

Push to the Docker repository

Our first node image above has been successfully generated. This image only exists locally for the time being. If you want everyone to pull it down and run it, you need to push it to the Docker Hub, and the command is push.

# # command
docker push [OPTIONS] NAME[:TAG]
Copy the code

The command used to discover Docker is very similar to git, of course, after all, it is a repository.

Docker push Luffyzh/Next-antD-scaffold :v1 pushed the local image to the remote. The command line output is as follows:

Push completed, go to docker Hub to check, sure enough, push successfully, everyone can use.

So, if it is the mirror of someone else’s warehouse how to find? Here you can use Docker Search to do this, as shown below:

Search ‘luffyzh’, will be matched to all images printed, the keyword is more accurate matching results are more accurate, and the query results also see the image we just pushed up.

Sentry

The simple study of Docker above has been completed, now we start to build the core part of the front-end monitoring system Sentry content.

Yes, Sentry relies on the Docker environment to build, and the above content is basically enough.

Check out the free version of Sentry and see how it works. The Next. Js project is still used as a practice.

The official monitoring

  • Step 1: Register an account to log in and create a project

In the image above, I chose to create a Node.js application. You can create any type of application.

  • Step 2: Insert Sentry code into the program

After creating a project, Sentry provides us with a DSN address, which is very important for identifying each application, uploading error messages, etc. We embed code in the project.

The actual code is in the project, so I won’t paste it, because the next article will cover it in more detail.

  • Write an error to throw an exception and see

Now that the project has been built and the code has been inserted, we can check the monitoring effect. Let’s write a few exceptions to see the specific effect as shown below:

As you can see from the image above, Sentry caught the exception we threw, had detailed error context information, and also provided an email notification service, which is really bad. Really sweet ~ love!!

Sentry actually provides a very good monitoring service for us, but the point is that it’s a fee, so it might not be affordable for small companies or individual developers. Sentry has probably taken this into account by offering a free open source service, and the documentation is really nice and friendly

There is a touch here, strong development team responsible development team really good, even the development documentation deployment documentation, is also written well. Here I feel that it really has nothing to do with the language, that is, no matter in Chinese or English, there is no generation gap, according to the core instructions can be basically successful, worthy of our learning ~ Docker and Sentry are the same.

Docker is used locally to build Sentry

Now it’s time to build your own local Sentry service. In fact, there is no big difference between local and server construction, so here for the convenience of explanation, with the local environment to do the explanation.

The author is a Mac OS system, other systems may be different, mainly official documents ~

Docker Install Sentry

Preparations before Installation

  • The Docker 17.05.0 +
  • Docker Compose 1.19.0 +
  • A dedicated (sub)domain to host Sentry on (for example, sentry.yourcompany.com).
  • At least 2400MB memory
  • 2 CPU Cores

The above requirements are basically met after we install Docker, and then we can use Docker to deploy Sentry service locally.

Step 1: Take the official warehouse and install it

git clone https://github.com/getsentry/onpremise.git
Copy the code

Unlike the other tutorials, it’s easy to just execute the installation file because the official help has been wrapped:

This version of direct automatic installation is the official update around July 2019, before July still need to do some related operations.

# Install configuration
cd onpremise && ./install.sh
Copy the code

If you execute without any error, then it is very good, the author side reported the following error, strength hit face, just said that the basic conditions are met 😂 :

Checking minimum requirements...
FAIL: Expected minimum RAM available to Docker to be 2400 MB but found 1998 MB
Copy the code

Use Docker info to find that the maximum available memory of docker on the computer is indeed only 1.952g = 1998MB.

I only know that docker memory is not enough, but there is a lot of computer memory, look up all kinds of information (Baidu/Google/Stack Overflow) also do not have the answer how to set docker memory, finally found that Mac OS to set:

Set up as shown above and proceed with the installation. And finally, if nothing else, it looks like this.

If there is no accident, but in fact there will be accidents, I gave the author install.sh Issue, and also solved the specific accident, if you started to install after reading the article, you should not encounter again. By the way, during the installation process, there will be a process of account registration, input email and password

After successful installation, run docker-compose up -d and visit http://localhost:9000 (Sentry default startup port 9000).

Then use the username and password we just logged in.

Step 2: Configure the mail service

In fact, simple monitoring requirements, we can also fully Cover through the log, Sentry’s more powerful function lies in error alarm, such as online error email, automatic Jira and so on. Here is a simple configuration of the mail service, because there are some holes here too.

Here, I use the SMTP service of mailbox 163, so I need to enable the SMTP authorization code of mailbox 163. The details are not described here, it is very simple ~

Then, open the onpremise directory above again:

The first step #
cd onpremise && cd sentry

Step # 2
vi config.xml
Copy the code

Then find the Mail Server and modify the corresponding service to your own Mail service:

# # # # # # # # # # # # # # #
# Mail Server #
# # # # # # # # # # # # # # #

# mail.backend: 'smtp' # Use dummy if you want to disable email entirely
mail.host: 'smtp.163.com'Mail. port: 465 // enable TLS, default mail service 25 mail.username:'your@163.com'// Your email address mail.password:'your smtp secret'// Here is your SMTP authorization code mail.use-tls:true/ / open the TLS# The email address to send on behalf of 
mail.from: 'your@163.com'// Who is the senderCopy the code

CD onpremise &&./install.sh needs to be re-installed. After the installation is complete, you can go to the Admin/Manage/Mail page to view:

Click the Send test email service, and if there is no problem, a test email will be sent to your email. Of course, I also said that if there is no problem, the road of life is bumpy, which is so easy to succeed at one time… The actual effect, failed, as shown below:

If something goes wrong, don’t be afraid, I don’t have the shame to ask, so I go to other people’s below to put forward the Mail Issue, then friendly communication and consult relevant literature, finally find a solution — use django_smtp_ssl as the Mail background to send emails:

  • Step 1: Installdjango_smtp_ssl
# 1 - Enter the directory
cd onpremise && cd sentry

# 2 - Edit dependent files
vi requirements.txt

# 3 - Type the following:

# Add plugins here
# Support SSL for sending emailsDjango - SMTP - SSL ~ = 1.0 redis - py - cluster = = 1.3.4Copy the code
  • Step 2: Modifyconfig.yml
# mail.backend: 'smtp' # Use dummy if you want to disable email entirely
mail.backend: 'django_smtp_ssl.SSLEmailBackend'// New mail.host:'smtp.163.com'Mail. port: 587 // 465 -> 587'your@163.com'
mail.password: 'your smpt sceret'// Note that this is not your email password mail.use-tls:true
# The email address to send on behalf of
mail.from: 'your@163.com'
Copy the code
  • Step 3: Reinstall
cd onpremise && ./install.sh
Copy the code

Then we send it again:

That’s it. That’s it. However, the following problems can sometimes occur:

After consulting, said that the mail service is actually through, but 163 mailbox there feel that this is a junk mail, did not send. However, after a lot of testing, I found that it is related to the network, if you use the Intranet in the company, it is easy to break down, if you use a personal mobile hotspot, you can send. It may be Intranet gateway port limit and so on. If you have studied it, you can comment and leave a message. I can add something

It is important to use TLS, because the SMTP:25 port is not open on a typical Linux server, and TLS is more secure.

Recommend the article

Docker

  • Docker_ entry? Just this one is enough!

  • Front-end domain Docker with Kubernetes

  • Docker Builds your first Node project to the server (full version)

My article is not a docker entry article, but to record their own use process only 😁, and the above several articles are very good, interested can go to see, if it is a big guy please skip, when I did not say anything,.

Sentry

Sentry is pretty much the same, because the official documentation is quite detailed, so I think you should go directly to the official website

conclusion

This article is just a preliminary test of water, the specific project deployment monitoring practice will be introduced in more detail in the next article ~ soldiers and horses are not moved, food and grass first, at least we have to put the environment out first is not ~ 😄

Front-end Monitoring Sentry – Next. Js Project monitoring practices