当前位置: 首页 > news >正文

一份运维监控的终极秘籍!监控不到位,宕机两行泪

有很多文章都提到过白盒监控和黑盒监控,以及监控的四个黄金指标。关于白盒与黑盒监控的定义,这里不再赘述。一般来说,白盒与黑盒分别从内部和外部来监控系统的运行状况,例如机器存活、CPU内存使用率、业务日志、JMX等监控都属于白盒监控,而外部端口探活、HTTP探测以及端到端功能监控等则属于黑盒监控的范畴。

本文将主要从白盒监控的采集入手,解答关于新系统如何添加监控的问题。

\"\"

黑盒与白盒监控

监控指标的采集

配置监控时,我们首要面对的是监控数据如果采集的问题。一般我们可以把监控指标分为两类:基础监控和业务监控

基础监控

包括CPU、内存、磁盘、端口和进程等机器、网络的操作系统级别的信息。通常情况下,成熟的监控系统(例如开源的Prometheus、Zabbix等)均会提供基础监控项的采集能力,这里不做过多介绍。但需要注意的一点,机器级别的基础监控指标一般并不能代表服务的真实运行状况,例如单台实例的故障对一个设计合理的分布式系统来说并不会带来严重后果。所以只有结合业务相关监控指标,基础监控指标才有意义

业务监控

业务监控指标由业务系统内部的服务产生,一般能够真实反应业务运行状态。设计合理的系统一般都会提供相关监控指标供监控系统采集。监控数据的采集方法一般可以分为以下几大类。

  • 日志:日志可以包含服务运行的方方面面,是重要的监控数据来源。例如,通过Nginx access日志可以统计出错误(5xx)、延迟(响应时间)和流量,结合已知的容量上限就可以计算出饱和度。一般除监控系统提供的日志采集插件外,如Rsyslog、Logstash、Filebeat、Flume等都是比较优秀的日志采集软件。

  • JMX:多数Java开发的服务均可由JMX接口输出监控指标。不少监控系统也有集成JMX采集插件,除此之外我们也可通过jmxtrans、jmxcmd工具进行采集。

  • REST:提供REST API来进行监控数据的采集,如Hadoop、ElasticSearch。

  • OpenMetrics:得益于Prometheus的流行,作为Prometheus的监控数据采集方案,OpenMetrics可能很快会成为未来监控的业界标准。目前绝大部分热门开源服务均有官方或非官方的exporter可供使用。

  • 命令行:一些服务提供本地的命令来输出监控指标。

  • 主动上报:对于采用PUSH模型的监控系统来说,服务可以采取主动上报的方式把监控指标push到监控系统,如Java服务可使用Metrics接口自定义sink输出。另外,运维也可以使用自定义的监控插件来完成监控的采集。

  • 埋点:埋点是侵入式的监控数据采集方式,其优点是其可以更灵活地为我们提供业务内部的监控指标,当然缺点也很明显:需要在代码层面动手脚(常常需要研发支持,成本较高)。

  • 其它方式:以上未涵盖的监控指标采集方式,例如Zookeeper的四字命令,MySQL的show status命令。

以上列出了几种常见的监控指标采集方法,在实际工作,如果没有现成的监控采集插件,则需要我们自行开发采集脚本。

监控的四个黄金指标

无论业务系统如何复杂,监控指标如何眼花缭乱,但万变不离其宗,监控的目的无非是为了解服务运行状况、发现服务故障和帮助定位故障原因。为了达成这个目的,Google SRE总结的监控四个黄金指标对我们添加监控具有非常重要的指导意义。下图给出四个黄金指标所包含的主要监控指标,下面我们就这四个黄金指标分别展开说明,并给出一些监控项的采集实例。

\"\"

四个黄金指标

错误:错误是指当前系统发生的错误请求和错误率

错误是需要在添加监控时首要关注的指标。在添加错误相关监控时,我们应该关注以下几个方面:

  • 基础监控:宕机、磁盘(坏盘或文件系统错误)、进程或端口挂掉、网络丢包等故障。

  • 业务监控:

    • 核心功能处理错误,每种系统都有特定的核心功能,比如HDFS的文件块读写、Zookeeper对Key的读写和修改操作。

    • 基础功能单元丢失或异常,这里的基础功能单元是指一个系统功能上的基本单位,例如HDFS的Block、Kafka的Message,这种基础数据的丢失一般都会对业务功能造成直接的影响。

    • Master故障,对于中心化的分布式系统来说,Master的健康状况都是重中之重。例如HDFS的NameNode、Zookeeper的Leader,ElasticSearch的MasterNode。

    • 可用节点数,对于分布式系统来说,可用节点数也是非常重要的,比如Zookeeper、ETCD等系统需要满足可用节点数大于不可用节点数才能保证功能的正常。

注意:除白盒监控外,主要功能或接口、以及内部存在明显边界的功能模块和上游依赖模块,都应该添加黑盒端到端监控

延迟:服务请求所需时间

服务延迟的上升不仅仅体现在用户体验的下降,也有可能会导致请求堆积并最终演变为整个业务系统的雪崩。

以下为延迟指标的主要关注点:

  • 基础监控:IO等待、网络延迟;

  • 业务监控:业务相关指标主要需要关注核心功能的响应时长。比如Zookeeper的延迟指标zk_avg_latency,ElasticSearch的索引、搜索延迟和慢查询。

注意:与错误指标类似,白盒延迟指标通常仅能代表系统内部延迟,建议为主要功能或接口添加黑盒监控来采集端到端的延迟指标

流量:当前系统的流量

流量指标可以指系统层面的网络和磁盘IO,服务层面的QpS、PV和UV等数据。流量和突增或突减都可能预示着系统可能出现问题(攻击事件、系统故障…)。一下为流量主要关注的方面:

  • 基础监控:磁盘和网卡IO;

  • 业务监控:核心功能流量,例如通过QpS/PV/UV等通常能够代表Web服务的流量,而ElasticSearch的流量可用索引创建速率、搜索速率表示。

饱和度:用于衡量当前服务的利用率

更为通俗的讲,饱和度可以理解为服务的利用率,可以代表系统承受的压力。所以饱和度与流量息息相关,流量的上升一般也会导致饱和度的上升。通常情况下,每种业务系统都应该有各自的饱和度指标。

在很多业务系统中,消息队列长度是一个比较重要的饱和度指标,除此之外CPU、内存、磁盘、网络等系统资源利用率也可以作为饱和度的一种体现方式。

  • 基础监控:CPU、内存、磁盘和网络利用率、内存堆栈利用率、文件句柄数、TCP连接数等;

  • 业务监控:

    • 基础功能单元使用率,大多数系统对其基础的功能单元都有其处理能力的上限,接近或达到该上限时可能会导致服务的错误、延迟增大。例如HDFS的Block数量上升会导致NameNode堆内存使用率上升,Kafka的Topics和Partitions的数量、Zookeeper的node数的上升都会对系统产生压力。

    • 消息队列长度,不少系统采用消息队列存放待处理数据,所以消息队列长度在一定程度上可以代表系统的繁忙程度。如ElasticSearch、HDFS等都有队列长度相关指标可供采集。

总结

以上总结了常见的监控指标采集方法,以及四个黄金指标所包含的常见内容。在实际工作中,不同的监控系统的设计多种多样,没有统一标准,并且不同的业务系统通常也有着特定的监控采集方法和不同的黄金指标定义,具体如何采集监控指标和添加告警都需要我们针对不同系统特点灵活应对。

文章出自京东云应用研发部,首发于公众号“京东云”:https://mp.weixin.qq.com/s/HGVTM30j5I9T8Q6B8DEvnQ

相关文章:

  • leetcode386. Lexicographical Numbers
  • 30秒的PHP代码片段(1)数组 - Array
  • docker-2-安装
  • 使用 QuickBI 搭建酷炫可视化分析
  • 使用rsyslog收集日志
  • 日剧·日综资源集合(建议收藏)
  • 码农张的Bug人生 - 见面之礼
  • Java求两个数平均值
  • 01炼数成金TensorFlow基本概念
  • Spark调度模块
  • 封装dialog弹窗
  • Spark2.4.0源码分析之WorldCount 默认shuffling并行度为200(九) ...
  • CentOS6 Shell脚本/bin/bash^M: bad interpreter错误解决方法
  • 搭建gitbook 和 访问权限认证
  • 测试开发系类之接口自动化测试
  • JavaScript-如何实现克隆(clone)函数
  • [ JavaScript ] 数据结构与算法 —— 链表
  • 【mysql】环境安装、服务启动、密码设置
  • 【从零开始安装kubernetes-1.7.3】2.flannel、docker以及Harbor的配置以及作用
  • 3.7、@ResponseBody 和 @RestController
  • Angularjs之国际化
  • bearychat的java client
  • Brief introduction of how to 'Call, Apply and Bind'
  • CODING 缺陷管理功能正式开始公测
  • ComponentOne 2017 V2版本正式发布
  • CSS魔法堂:Absolute Positioning就这个样
  • nginx(二):进阶配置介绍--rewrite用法,压缩,https虚拟主机等
  • Spring技术内幕笔记(2):Spring MVC 与 Web
  • SQLServer之索引简介
  • Web Storage相关
  • XForms - 更强大的Form
  • Yii源码解读-服务定位器(Service Locator)
  • 翻译:Hystrix - How To Use
  • 回顾2016
  • 前端学习笔记之观察者模式
  • 设计模式走一遍---观察者模式
  • 微信支付JSAPI,实测!终极方案
  • 译有关态射的一切
  • MPAndroidChart 教程:Y轴 YAxis
  • 我们雇佣了一只大猴子...
  • ​业务双活的数据切换思路设计(下)
  • #Ubuntu(修改root信息)
  • (1)(1.13) SiK无线电高级配置(五)
  • (14)目标检测_SSD训练代码基于pytorch搭建代码
  • (aiohttp-asyncio-FFmpeg-Docker-SRS)实现异步摄像头转码服务器
  • (cljs/run-at (JSVM. :browser) 搭建刚好可用的开发环境!)
  • (libusb) usb口自动刷新
  • (附源码)ssm学生管理系统 毕业设计 141543
  • (含react-draggable库以及相关BUG如何解决)固定在左上方某盒子内(如按钮)添加可拖动功能,使用react hook语法实现
  • (收藏)Git和Repo扫盲——如何取得Android源代码
  • .\OBJ\test1.axf: Error: L6230W: Ignoring --entry command. Cannot find argumen 'Reset_Handler'
  • .jks文件(JAVA KeyStore)
  • .NET 8 编写 LiteDB vs SQLite 数据库 CRUD 接口性能测试(准备篇)
  • .NET 使用 ILMerge 合并多个程序集,避免引入额外的依赖
  • .vimrc php,修改home目录下的.vimrc文件,vim配置php高亮显示