错误监控——自建sentry

创建sentry服务端

下载最新版本镜像

地址:https://github.com/getsentry/self-hosted/releases/tag/22.8.0

运行批处理文件
./install.sh
启动docker-compose环境
docker-compose up -d
打开本地服务

http://localhost:9000/

登入账号

进行客户端配置

以React为例

首先安装配置环境
npm install --save @sentry/react @sentry/tracing
将sentry配置放入项目中

时机应当尽可能的早

import React from "react";
import { createRoot } from 'react-dom/client'
import * as Sentry from "@sentry/react";
import { BrowserTracing } from "@sentry/tracing";
import App from "./app.jsx";

Sentry.init({
  dsn: "http://0324e0c287304017bf1cba0deabf5445@localhost:9000/4",
  integrations: [new BrowserTracing()],
  release: 'test2',
  tracesSampleRate: 1.0,
});

const container = document.getElementById('root');
const root = createRoot(container); 
root.render(<App tab="home" />);

此时报错已经可以上报给服务器了


错误追踪

sentry-cli环境配置

由于我们下面会用到sentry-cli,为了避免多次在命令行传入信息,先来进行环境配置

安装sentry-cli框架

npm i @sentry/cli -g 

npm install sentry-cli-binary -g
获取API Token

进入 <你的服务器地址>/settings/account/api/auth-tokens/
点击创建新API Token

NOTE:记得勾选project:write

登录sentry
sentry-cli login

此时控制台显示以下信息,token处填入上一步获取到的token即可

Sentry server: sentry.io
Open browser now? [y/n] y
Enter your token:

输入完成之后会给你存储位置

Stored token in /Users/xxx/.sentryclirc

添加sentry配置
打开上一步存储的位置,进行信息补充

  • url是sentry服务的地址
  • org是个人面板种组织名称
  • project是项目名称
[auth]
token=xxx

[defaults]
url=<你的服务器地址>
org=<你的组织地址>
project=<你的项目地址>
上传sourceMap

由于生产环境发布的内容往往已经经过了压缩,因此上报的信息是无法对应到源码行列号的。可以通过往sentry服务端上传sourceMap的方式来进行错误追踪

方案一:直接上传

创建release

sentry-cli releases -o sentry new -p react test1

参数说明:

  • -o:组织的名字
  • -p:项目的名称
  • test1: 这个是release的名称

以上的组织名称、项目名称、release名称都是自己起的。按照实际情况填写就可以了。因为项目相关信息填写多处用到,可以直接配置sentry-cli。参见sentry-cli部分

发布sourceMap

sentry-cli releases files test1 upload-sourcemaps --url-prefix "~/js" --validate ./dist/js

此时该项目的错误上报可以追踪到具体的行列号了

方案二:配置webpack插件

 devtool: 'source-map',
 plugins: [
    new SentryWebpackPlugin({
      // sentry-cli configuration - can also be done directly through sentry-cli
      // see https://docs.sentry.io/product/cli/configuration/ for details
      authToken: process.env.SENTRY_AUTH_TOKEN,
      org: "sentry",
      project: "react",
      release: "test2",
      include: ".",
      ignore: ["node_modules", "webpack.config.js"],
    })
 ]

将该配置放在生产环境下,打包后可自动上传sourceMap

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值