美文网首页让前端飞Web前端之路
Node应用没有错误监控怎么行?

Node应用没有错误监控怎么行?

作者: 金炳 | 来源:发表于2019-05-21 16:35 被阅读0次

    编者注:作者是网易资深前端@金炳,当前负责网易严选自研Node框架建设工作。做过前端、后端、产品设计,是一名全栈工程师。目前致力于Node应用框架研究开发与生态建设,实践Node应用在Serverless、Faas场景下的迁移和落地,探索Service Mesh在Node应用中的价值。

    本文讲解node,以及node+typescript+sourcemap,两种类型的Node应用监控

    一、背景

    经过了一阵子的学习时间,那个看了一些Node开发技巧的童鞋,终于开发出了他人生中第一个后端应用。热血沸腾,写出了一个应用,好开心,然后开启了他漫漫长路的功能迭代的时代,准备迎接他产品的黄金时代。

    但是突然有一天,发现他的用户,说这怎么不能用,那怎么报错提示,然后他花了大量的时间,去帮他们定位,去复现各种问题,去重构,去review代码,终于解决了这些问题。但是这个过程中,因为解决问题肯定要时间,所以慢慢的用户也就流失了。

    上面这个情况,应该是大部分后端经历过的问题,也是很多初级开发遇到的痛点。

    但是,这整个过程中,其实有很多可以改进的地方,本文,作为以一个过来人的经验,准备讲讲Node的错误监控,来提升我们自身的成长速度以及错误定位速度。

    二、监控

    错误监控,是监控里面的一种,我们常常将监控做到三个维度.

    机器的性能,内存,CPU这些的系统监控

    调用失败,RT,QPS等类型的应用监控

    业务卖的怎么样的业务监控

    2.1 系统监控

    系统监控,比如你的机器,是不是磁盘读写出问题了,CPU是不是要被占用光了,内存是不是要没了。

    2.2 调用失败,RT,QPS等类型的应用监控

    整个系统,调用出错了多少次,QPS有多少,这个类型的监控。

    2.3 业务监控

    比如运营同学会问,"开发小哥哥,今天我负责的某某商品今天销量如何?", "我要做活动,但是什么时间开售比较好呢?", "我去别的公众号投了广告,但是广告有没有带来效果,我下次要不要再投他们家广告呢"。

    这类,就需要我们开发同学,去做业务监控喽。

    所以我们看到,错误监控,属于应用类型的监控,只是我们监控的一个环节,如果后续希望看到其他文章介绍,请关注我们。

    三、搭建错误监控系统

    最快的解决方式,就是去了解这块有什么知名的开源解决方案以及哪些我们可以用的服务。

    有哪几个呢?

    Fundebug-不放过每一个BUG

    sentry

    总的来说:

    上面的以前是免费的,后来收费了。下面的开源的,挺好用的。所以下面我们就介绍sentry相关应用吧,毕竟文章不能太长,哈哈哈。

    3.1 sentry是什么?

    sentry是一个开源的实时错误报告工具,支持web前后端,移动应用以及游戏,支持Python, OC,Java,Go, Node, Django等主流编程语言和框架,还提供了Github、Slack、Trello等常见开发工具的集成。

    3.2 文档地址

    官网地址:https://sentry.io/welcome/

    github地址:https://github.com/getsentry/sentry

    整体项目是用django开发的后端+django的后端模板渲染的前端。

    3.3 安装方法

    这边用官方的docker-compose的方式进行安装,关于其他安装方法,随便搜,毕竟知名呀,如果你以前没用过,说明要赶紧的了哈。

    官方的一个方式:

    步骤一:

    git clone代码.仓库地址: https://github.com/getsentry/onpremise.git,然后下载完代码后进入这个目录进行操作。

    gitclone https://github.com/getsentry/onpremise.git

    步骤二:

    docker volumecreate--name=sentry-data && docker volume create --name=sentry-postgres

    步骤三:

    把他的环境配置文件拷贝一份,修改。

    cp-n.env.example.env

    步骤四:

    执行build

    docker-compose build

    步骤五:

    产生一个key。

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

    会提示给我们一个key的。

    然后将这个key,修改vim .env然后填进去。

    步骤六:

    数据库orm的执行,生成数据库表和数据库初始数据

    docker-compose run--rm web upgrade 

    然后他会提示我们创建一个账号,那这时大家输入一个账号。

    步骤七:

    运行

    docker-compose up -d

    步骤八:

    打开我们的网页访问: http://127.0.0.1:9000,看到以下界面:

    然后我们输入账号密码后,他会进入这个页面:

    关于Sentry这样的错误监控,在项目开发中挺有用的,有些公司采用自建,有些是用这类开源项目二次开发,所以还没学会的同学,赶紧试试吧。

    七、结论

    本文其实也只是讲解了sentry这块的错误监控的一小块,例如react这类前端项目里面也可以用。还有邮件报警等等。

    如果听了之后,对你有所启发和帮助,希望能帮忙转发一下,如果有问题,可以关注下面微信公众号联系我。

    公众号名字: Node全栈进阶

    相关文章

      网友评论

        本文标题:Node应用没有错误监控怎么行?

        本文链接:https://www.haomeiwen.com/subject/obbjzqtx.html