程序员Java 杂谈

【190308】如何做监控告警

2019-03-25  本文已影响0人  林湾村龙猫

“哎哎,XX,很多客服反馈这个业务挂了怎么回事,赶紧看看。” 正在安安静静写代码的你心头一颤,出问题了。赶紧打开业务链接看看,真出问题了,怎么办,怎么查问题?一脸闷逼。

据说现代医学始于听诊器的发明,医生凭借该物收集放大从各个器官发出的声音以诊断问题。

我一直喜欢把我们做后台做业务的,称之为在快速飞行的飞机上修零件。边飞边升级。。在飞机上有各种各样的仪表盘指示着各个模块的运行情况。如果没有这些,估计只有等到飞机坠毁的时候才知道出问题了,这个时候为时已晚。

飞机如此,我们的业务与服务又该有什么样的仪表盘/听诊器呢?

这是我这篇文章想说的,当我们自己的后台服务及业务运行情况生病出问题了,怎么做好服务/业务的仪表盘-业务监控告警

意义与想要达到的效果

没有一个系统是100%没有问题的,那么我们要保证我们的业务和服务的可靠性。我们希望达到如下的效果:

需要想清楚的问题

为了达到这样的效果,我不得不思考我们需要解决的问题和点。

1.什么是我们需要关心的点

只有了解你的业务,才能做出更好的系统设计。

通常来说,只有了解你的业务,你才知道哪些点应该是你重点关注的、哪些点是容易根据业务进展而做扩展的。一般来讲,一个业务服务应该关注的点,我觉得如下:

2.怎么定义异常情况

通常来讲,如果没有什么特殊处理,今天同一时间与昨天同一时间的监控数值应该会基本一致。基于这样一个依据,我们可以做一些比较以发现问题。

3.什么时候发现异常情况

通常来讲,做一件事情,投入的成本时效性准确性三者之间同时达到比较好的状态是一件及其困难的事情。这个时候我们希望投入的成本带来最大化的,部分作出妥协。

冲突

4.异常的程度如何

如同一个人生病一样,可能只是一个小感冒,也有可能得了大病。我们不可能为了小感冒而住院,也不可能忽略了大病的存在。因此我们需要给异常分级处理。

5.怎么通知

跟上面异常程度相对应的,我们需要有不同的告警方式通知关注者,既减少骚扰有能及时发现问题。
紧急程度依次是:短信/电话 > IM(微信钉钉等) > 数据图表

6.怎么做到是告警而非骚扰

这一点,我觉得把握住两点就可以:

如何去做的问题

我大概分3个阶段去说明一下

1.简单处理

当业务或系统刚开始做的时候,这个时候也需要监控告警,但是暂时又没有这么大的人力去做,这个时候我们可以简单处理一下,对几个关键节点根据数据库记录,做隔日统计和分析,先做一个。完成从0到1的过程。

简单处理

2.业务数据计算统计模块

当业务或系统成长到一定阶段,这个时候简单的全量扫表会出现各种问题,比如性能耗时等等,这个时候,我们可以将监控告警独立成单独的模块做处理。

业务数据计算统计模块.png

3.日志收集分析系统

随着业务或系统的发展,可能不止一个业务或系统需要这样的监控告警的能力,这个时候,我们可以将监控告警做成一个系统,可供多个业务或系统使用。抽象成业务关注的节点通过行为日志上报,大数据中心做数据分析和存储。

日志收集分析系统.png

效果

针对一些比较关注的点,当出现比较大的下滑或上升的时候就可以人工介入。


实时告警

这个时候,我们收到了告警,有时候很难一下子发现问题,这个时候曲线图去查问题就要方便很多。

image.png

最后,希望看到最后的你有所收获。>-<

上一篇下一篇

猜你喜欢

热点阅读