专栏首页杨建荣的学习笔记应用异常监控利器 Sentry 搭建与学习笔记

应用异常监控利器 Sentry 搭建与学习笔记

什么是Sentry?

Welcome to the Sentry documentation. Sentry is an open-source company,providing an application monitoring platform that helps you identifyissues in real-time. Here we cover everything about the product, the platform integrations, and self-hosted Sentry.欢迎使用Sentry文档。Sentry是一家开源公司,提供了一个应用程序监视平台,可以帮助您实时识别问题。在这里,我们涵盖了有关产品,平台集成和自托管Sentry的所有内容。【通俗讲的讲】我们可以使用Sentry平台实时地监控我们的应用或服务、并且可以收集相关运行时错误或异常日志信息,在第一时间将错误信息推送至我们的后台或邮件组等。这样不仅能主动帮我们第一时间发现线上问题,而且很好的保留了异常发生时的“现场”,更有助于我们快速定位问题根源,提高解决问题的效率,逐步提高产品的稳定性和用户体验。

官网及文档

https://sentry.io/welcome/

https://docs.sentry.io

https://docs.sentry.io/guides/

https://docs.sentry.io/platforms/go/

Sentry的原理

  • 在Sentry后台注册相关账号并使用关联Dsn-key。(该key是关联应用和后台平台的桥梁)
  • 在我们的应用中潜入对应语言的SDK埋点,并关联上述key;

简单到仅用一个init方法就可以搞定。

  • 捕获异常并埋点,将异常信息第一时间推送至后台平台。

Sentry平台的优势

  • 支持各种主流语言或框架。
  • 跨平台性较好,并支持容器化安装搭建等。
  • 平台自建成本低、部署简单、集成方便。

Sentry-Golang版的支持

  • 官方文档 https://docs.sentry.io/platforms/go/
  • fasthttp框架支持 https://docs.sentry.io/platforms/go/fasthttp/

平台搭建与实践

  • 虚拟机环境
  • CentOS Linux release 7.6.1810 (Core)
  • Sentry Docker 镜像获取

https://github.com/getsentry/docker-sentry

https://github.com/getsentry/onpremise

  • 安装部署

https://github.com/docker-library/docs/tree/master/sentry

1.docker run -d --name sentry-redis redis
2.docker run -d --name sentry-postgres -e POSTGRES_PASSWORD=secret -e POSTGRES_USER=sentry postgres
3.docker run --rm sentry config generate-secret-key
这一步会生成一个密钥key,比如 *l%)ti9=v#!pt__!#hpz3g33tq3hy2afpv%sda6^^ghr24)k4q ,先记下来,后面步骤中多个容器会共享该key
4.docker run -it --rm -e SENTRY_SECRET_KEY='*l%)ti9=v#!pt__!#hpz3g33tq3hy2afpv%sda6^^ghr24)k4q' --link sentry-postgres:postgres --link sentry-redis:redis sentry upgrade
5.docker run -d -p 9090:9000 --name my-sentry -e SENTRY_SECRET_KEY='*l%)ti9=v#!pt__!#hpz3g33tq3hy2afpv%sda6^^ghr24)k4q' --link sentry-redis:redis --link sentry-postgres:postgres sentry
6.docker run -d --name sentry-cron -e SENTRY_SECRET_KEY='*l%)ti9=v#!pt__!#hpz3g33tq3hy2afpv%sda6^^ghr24)k4q' --link sentry-postgres:postgres --link sentry-redis:redis sentry run cron
7.docker run -d --name sentry-worker-1 -e SENTRY_SECRET_KEY='*l%)ti9=v#!pt__!#hpz3g33tq3hy2afpv%sda6^^ghr24)k4q' --link sentry-postgres:postgres --link sentry-redis:redis sentry run worker
上述几步完成后,查看下刚才创建的容器以及运行状态是否完好:
➜  /tmp docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES
7ed2439c527c        sentry              "/entrypoint.sh run …"   3 hours ago         Up 3 hours          9000/tcp                 sentry-worker-1
f3779877d102        sentry              "/entrypoint.sh run …"   3 hours ago         Up 3 hours          9000/tcp                 sentry-cron
9c190bd613a6        sentry              "/entrypoint.sh run …"   3 hours ago         Up 3 hours          0.0.0.0:9090->9000/tcp   my-sentry
188c744c2f21        postgres            "docker-entrypoint.s…"   4 hours ago         Up 4 hours          5432/tcp                 sentry-postgres
abad0564ca2b        redis               "docker-entrypoint.s…"   4 hours ago         Up 4 hours          6379/tcp                 sentry-redis
然后检查下宿主机防火墙或安全组策略,放行上述映射的9090端口;
  • 在浏览器中访问并测试

http://localhost:9090/auth/login/sentry/

  • 访问成功后登陆

如果成功,您会看到如下页面

然后用上述第4步中填入第账户登陆并配置,成功后进入首页

  • 简体中文设置

打开左上角第个人中心,然后点击User settings->language-> 选择简体中文即可.

  • 然后可以创建一个团队,如名称为server
  • 然后创建一个项目,如go-sentry-test
  • 将sdk潜入Golang应用,如go-sentry-test.go
import (
	"errors"
	"time"
	"github.com/getsentry/sentry-go"
)
func main() {
	sentry.Init(sentry.ClientOptions{
		Dsn: "http://60e443996c464def804082d3c7e04de3@localhost:9090/2",
	})
	sentry.CaptureException(errors.New("my error"))
	// Since sentry emits events in the background we need to make sure
	// they are sent before we shut down
	sentry.Flush(time.Second * 5)
}

本地运行并模拟错误将日志上报

go run go-sentry-test.go

  • 刷新后台页面,看到刚刚咱们应用上传的error已经在issues列表中了,如图
  • 并且还支持直接潜入到web框架,如以fasthttp为例:
import (
	"fmt"
	"net/http"
	"github.com/getsentry/sentry-go"
	sentryfasthttp "github.com/getsentry/sentry-go/fasthttp"
)
// To initialize Sentry's handler, you need to initialize Sentry itself beforehand
if err := sentry.Init(sentry.ClientOptions{
	Dsn: "https://079843729765443f982ef8f3aea18766@o396662.ingest.sentry.io/5250281",
}); err != nil {
	fmt.Printf("Sentry initialization failed: %v\n", err)
}
// Create an instance of sentryfasthttp
sentryHandler := sentryfasthttp.New(sentryfasthttp.Options{})
// After creating the instance, you can attach the handler as one of your middleware
fastHTTPHandler := sentryHandler.Handle(func(ctx *fasthttp.RequestCtx) {
	panic("y tho")
})
fmt.Println("Listening and serving HTTP on :3000")
// And run it
if err := fasthttp.ListenAndServe(":3000", fastHTTPHandler); err != nil {
	panic(err)
}
  • 直接使用官方提供的admin后台做测试或学习

上述是自己完整到搭建一下sentry,如果仅是为了学习或测试一下,并想节省时间,则可以直接在官方的后台https://sentry.io/signup/

注册一个账号,然后将sdk潜入到自己的测试应用中看效果,如

package main
import (
    "log"
    "time"
    "github.com/getsentry/sentry-go"
)
func main() {
    err := sentry.Init(sentry.ClientOptions{
        // Either set your DSN here or set the SENTRY_DSN environment variable.
        Dsn: "https://xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx@xxxxxxx.ingest.sentry.io/xxxxxxx",//这里需要替换为您自己的Dsn
        // Enable printing of SDK debug messages.
        // Useful when getting started or trying to figure something out.
        Debug: true,
    })
    if err != nil {
        log.Fatalf("sentry.Init: %s", err)
    }
    // Flush buffered events before the program terminates.
    // Set the timeout to the maximum duration the program can afford to wait.
    defer sentry.Flush(2 * time.Second)
    //sentry.CaptureException("自定义运行时错误1")
    sentry.CaptureMessage("自定义error")
}

效果如下

本文分享自微信公众号 - 杨建荣的学习笔记(jianrong-notes),作者:巴文茂

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2020-06-22

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 应用异常监控利器 Sentry 搭建与学习笔记(修正版)

    Sentry是一家开源公司,提供了一个应用程序监视平台,可以帮助您实时识别问题。 在这里,我们涵盖了有关产品,平台集成和自托管Sentry的所有内容。【通俗讲的...

    jeanron100
  • Maxwell和Canal的选型和规划

    关于Maxwell和Canal的选型和规划,之前在团队内部也讨论过几次,从功能和长期的支持,定制方面,似乎哪个方面都不是很好比较,毕竟根据每个企业的特点,都有难...

    jeanron100
  • 浅谈DBA技术栈的变化

    之前写过一篇 DBA技能发展变化小结,效果还不错,今天突然想到了一个点,那就是DBA技术栈的发展,我们来简单聊一聊。

    jeanron100
  • 应用异常监控利器 Sentry 搭建与学习笔记(修正版)

    Sentry是一家开源公司,提供了一个应用程序监视平台,可以帮助您实时识别问题。 在这里,我们涵盖了有关产品,平台集成和自托管Sentry的所有内容。【通俗讲的...

    jeanron100
  • Installing sentry 9.0.0 with postgresql in Centos7

    Sentry是一个开源错误跟踪工具,可帮助您实时监控和修复bug。支持 Python、OC、Java、Go、Node、Django、RoR 等主流编程语言和框架...

    阿dai学长
  • sentry部署整理 原

    sentry是python开发的一个应用,使用python uWSG框架运行,所有安装完sentry要记得在nginx的代理上禁用掉/admin路径,不然uws...

    domain0
  • sentry:解决给redis设置密码后启动报错

    出于安全考虑,给redis server设置了密码,同时修改了sentry的配置文件/etc/sentry/config.yml

    donghui
  • 安装sentry

    Sentry 是一个开源的实时错误报告工具,支持 web 前后端、移动应用以及游戏,支持 Python、OC、Java、Go、Node、Django、RoR 等...

    aox.lei
  • slenium模拟登陆知乎2020

    想看登录知乎的到这里就ok了,可以撤退了,如果对selenium不太熟悉的可以直接拉到最后,参考资料里,给各位指好路了,没办法,来者是客,为了满足各位,真是老费...

    诡途
  • 瑞海吴宁海:“行业+AI”,发现电力领域新蓝海 | 镁客请讲

    镁客网

扫码关注云+社区

领取腾讯云代金券