从零构建Sentry v10 进行异常上报

简介

Sentry 是一个开源的实时错误追踪系统,可以帮助开发者实时监控并修复异常问题。它主要专注于持续集成、提高效率并且提升用户体验。

下面是Sentry官网支持的产品

image

使用官网服务

作为大多数个人开发者和中小企业,可以直接使用Sentry官网)提供的云服务,你只需要注册一个Sentry账号,就可以快速享受到集中处理异常日志的服务。

本地安装Sentry服务

官网支持dockerpython安装两种方式,这里采用docker的方式
具体有什么疑问可以查看官网https://docs.sentry.io/server/installation/

安装docker

具体可以看之前记录的文章重头开始学Docker

安装docker-compose

  • 安装wget
yum -y install wget
  • 安装pip
# 如果使用 wget下载https开头的网址域名 时报错,你需要加上 --no-check-certificate (不检查证书)选项
wget https://bootstrap.pypa.io/get-pip.py --no-check-certificate  # 下载文件

python get-pip.py #执行安装

pip -V #查看pip版本

  • 安装docker-compose
sudo pip install docker-compose # 安装 docker-compose
docker-compose -v #查看docker-compose 版本

注意这里我在安装docker-compose报了这个错误

image

执行如下命令

sudo pip install --ignore-installed requests

安装完成之后再安装docker-compose

参考至:https://blog.csdn.net/guoshaoliang789/article/details/96878731

构建Sentry

  • github上拉取源码
git clone https://github.com/getsentry/onpremise.git

注意你需要保证你的Docker 17.05.0+ Compose 1.19.0+ 同时还需要拥有least 2400MB RAM

image

下载完成之后进入该目录。查看文件如下

image
  • 开始构建镜像
docker-compose build --pull

但是出了个问题,问题描述说是仓库不存在或可能需要“docker登录”:拒绝:请求访问的资源被拒绝

image

尝试解决问题:先执行登录操作

docker login
image

登录成功之后再次执行之前的命令,发现还是报错,我们搜索一下Docker网站上关于sentry-onpremise-local镜像,我们手动去pull

执行如下命令

docker image pull viitanener/sentry-onpremise-local
image

拉取成功之后,再次执行之前的命令。

参考至https://www.cnblogs.com/meloncodezhang/p/11229778.html

最后发现还是没用,但是在github issues中发现了同样的问题

这是问题链接https://github.com/getsentry/onpremise/issues/278

image

执行如下命令

docker-compose build --pull --force-rm web
docker-compose build --force-rm
image

发现build成功

  • 生成秘钥

进入sentry文件夹,将默认的config.example.ymlsentry.conf.example.py重命名为config.ymlsentry.conf.py。执行如下命令

cp config.example.yml config.yml
cp sentry.conf.example.py sentry.conf.py

执行如下命令生成秘钥

docker-compose run --rm web config generate-secret-key

将生成的秘钥添加到config.ymlsystem.secret-key字段上

image
  • 进行 Web 服务迁移

执行如下命令开始服务迁移

docker-compose run --rm web upgrade
image
image

正常情况下是会出现输入账号密码的步骤的,如果不可以请详细查阅这个issue

执行以下命令

 docker-compose run --rm web createuser
  • 运行 sentry
docker-compose up -d
image
  • 注意:错误解决

执行之后发现如下问题,判断可能是docker没有启动的问题

image

执行如下命令

service docker status  # 查看docker服务是否启动
systemctl start docker # 启动docker
image

再次执行安装

又发生如下错误

image

执行如下命令

dig @114.114.114.114 registry-1.docker.io
image

将上诉几个地址写入hosts文件后再次安装

  • 部署Sentry成功

打开浏览器输入ip:9000,如下图说明安装成功

image

注意,如果没有打开,请检查服务器防火墙与安全组是否开放9000端口

image
  1. Root URL:默认为部署的地址,后面会用到,sentryclirc文件里的url属性
  2. Admin Email 管理员邮箱
  3. Email From 邮件的发送地址息,填邮箱服务商的地方比如smtp.qq.com
  4. SMTP PORT Smtp服务的端口默认25,使用tls就是567
  5. SMTP username 用户名 qq邮箱账号
  6. SMTP password 密码 qq邮箱授权码(不是密码)
  • 修改邮箱设置

打开sentry/config.yml文件,编辑如下信息:

具体配置查看这里https://docs.sentry.io/server/config/#mail

image

注意要将服务器防火墙与服务器安全组的邮箱端口放开,

注意:如果使用Sentry10的话 使用tsl邮箱端口必须为567不然会报错

重新执行以下命令

docker-compose build --pull --force-rm web
docker-compose build --force-rm
docker-compose run --rm web upgrade
docker-compose up -d
image

可以看到邮箱信息已经修改掉了,下面我们发送一封测试邮件,点击下方的Test Settings

image

至此,邮箱服务也修改完成

Sentry使用

创建项目

  • 开始创建,选择Project->React->Create Project
image
  • SDK的使用
image
  • DSN地址
image
  • org组织名称


    image
  • project项目名称


    image
  • Create Token创建token


    image

务必勾选project:write

image

image

前端进行使用

安装webpack插件

npm install @sentry/webpack-plugin -S

添加.sentryclirc文件

[defaults]
url=sentry 服务的url #比如安装的是192.168.0.1:9000
project = 项目名字
org= 项目组织 上面有写在哪可以取到

[auth]
token=api token # 登录控制台获取
  • 关于url:就是你部署Sentry的地址
  • 关于project:
  • 关于org:
  • 关于token:

修改.umirc.js文件

const SentryPlugin = require('@sentry/webpack-plugin');
export default {
  chainWebpack(config, { webpack }){
    // 拿不到process.env.RELEASE_VERSION
    if (process.env.UMI_ENV == 'prod'){
      config.plugin("sentry").use(SentryPlugin, [{
        ignore: ['node_modules'],
        include: './dist', //上传dist文件的js
        configFile: './sentryclirc', 
        release:release, // 版本号
        deleteAfterCompile: true,
        urlPrefix: '~/static/' //静态资源路径前缀
       }])
    }
  },
 }
  • 关于urlPrefix如果你的静态资源是htps://cdn.xxx.com/static/那么该值就是~/static/,自动省去协议与主机地址

安装@sentry/browser

使用的时候需要结合这个包使用

npm i @sentry/browser -S

使用

  • 在项目的根文件下使用
import * as Sentry from '@sentry/browser';

const SENTRYSDK = '就是Sentry配置的DSN'

Sentry.init({dsn:SENTRYSDK,release: process.env.RELEASE_VERSION,debug: true,});
  • 结合React的生命周期使用
componentDidCatch(error, errorInfo) {
    Sentry.withScope((scope) => {
      scope.setExtras(errorInfo);
      const eventId = Sentry.captureException(error);
      this.setState({ eventId });
    });
}
  • 主动上报
Sentry.captureMessage('Hello, world!'); // 上报信息
Sentry.captureException(new Error('Good bye')); // 上报异常
Sentry.captureEvent({ // 上报事件
  message: 'Manual',
  stacktrace: [
    // ...
  ],
});

关于

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350

推荐阅读更多精彩内容