zoukankan      html  css  js  c++  java
  • 如何保障系统稳定?Grafana+Prometheus监控系统搭建

    一个好的管理系统可以为服务的高可用、高并发提供重要的保障。以下我们将为大家介绍如何通过一套完备的监控系统,帮助我们快速解决问题,保障系统服务的稳定运行:
    一、影响系统稳定性的常见问题及排查方案:
    • 网络超时
    这种情况有两种方式可以进行排查。
    方式一:
    查看反馈的那段时间内外部网络情况,比如查看运营商网络的PING监控和出口网络流量情况,确认是否出现网络抖动的情况;
    继续查看Nginx网关监控的请求耗时情况与 access log 日志,确认服务接口是否存在不稳定的情况;
    最后查看内部服务执行情况、服务的请求量、线程池队列大小以及是否存在慢日志,确定网络超时是否由业务请求量过大或者服务不够稳定造成的;
    方式二:
    通过网络抓包,分析抓包文件来排查网络超时原因。具体操作大家可以自行搜索wireshark教程。
    • 业务请求失败
    这种情况基本上是由客户触发了系统异常的业务逻辑所导致的,具体原因我们可以在日志监控系统中查看。在一定时间内推送系统中某个异常出现次数超过阈值,会触发日志监控系统的告警机制,系统会自动通知其开发人员去查看具体原因,并联系客户告知异常原因和解决方案。比如客户的出口IP发生变化,没有在我们开发者中心及时更新IP白名单,会导致客户的请求被系统拦截,返回请求失败结果。
    • 消息下发延迟
    这种情况的出现存在多种原因,一般情况下,我们排查的思路是首先通过查看全链路监控中哪个服务的耗时特别严重,再通过主机监控推送系统查看这个服务所在主机的CPU使用率是否过高,以此判断是否是某个线程异常引起的。接着,我们查看磁盘读写性能是否过低,是否存在主机内存剩余过低或者磁盘损坏的情况。最后,我们查看服务的old区监控,是否存在频繁的垃圾回收现象,以及是否存在服务内存溢出或服务线程异常情况,结合服务的dump和jstack文件,进一步分析排查具体的原因。
    除了上述提到的内部系统监控,我们也会在第三方机房的环境下模拟客户行为,主动调用消息推送API接口,根据返回的结果,来监控推送系统的运行情况是否正常。当出现服务异常反馈时,我们会在第一时间告警并快速响应和处理,确保客户的业务不受影响。
    由此可见,监控系统在保障推送系统的高并发和高可用中发挥了重要的作用。想要了解更多关于监控系统搭建的同学可以看下文的介绍,我们通过开源组件Prometheus、Grafana和docker容器,教大家快速搭建一套完善的监控系统。

    二、落地方案
    关于监控相关数据,这里以JMX的Metrics数据展示作为demo样例:

    1. 通过JMX Exporter第三方jar,demo以agent运行方式对外展示数据,方便Prometheus采集数据;
    2. 开源系统Prometheus采集并存储数据;
    3. 开源系统Grafana,以图表形式展现相关性能指标;

    三、落地步骤
    • 启动程序
    java -javaagent:./jmx_prometheus_javaagent-0.12.0.jar=8085:config.yaml -jar demo.jar
    • 运行Prometheus
    1、配置prom-jmx.yml
    scrape_configs:

    • 运行Grafana
    1、配置grafana.ini(以邮件告警为例)
    [smtp]
    enabled = true
    host = smtp.gmail.com:587
    user = example@gmail.com
    password = <邮箱密码>
    skip_verify = true
    from_address = example@gmail.com
    from_name = Grafana
    2、运行容器
    docker run -d --name=grafana -p 3000:3000
    -v $PWD/grafana.ini:/etc/grafana/grafana.ini
    grafana/grafana
    浏览器输入:http://localhost:3000,用户名和密码初始均为admin
    浏览器输入:http://localhost:3000/alerting/notification/new,验证邮件告警配置是否正确
    3、配置数据源
    浏览器输入:http://localhost:3000/datasources
    a. 点击添加数据源按钮;
    b. 选择Prometheus作为数据源;
    c. 编辑数据源
    - 修改数据源名字

    四、效果展示
    上述步骤完成后,我们就可以在Grafana中查看相关监控信息,效果如下:

    五、总结
    以上我们介绍了如何通过开源组件和docker容器,快速搭建一套完善的监控系统的方法。监控系统不仅需要监控我们所关注的服务性能指标,还需要自主监控系统的各种异常日志、慢日志等。多个维度的系统监控,可以为发现、定位、解决、总结问题等提供帮助,为后续服务的性能优化、缩扩容以及维持系统的稳定等提供重要依据。
    针对重要的监控项,我们需要添加告警信息。监控的指标设置可以包含多方面,但选择需要告警的监控项时则要谨慎,应保证设置的阈值合理。

    重点监控项总结:
    结合我们平时系统服务的维护情况,我们将需要重点关注的监控项总结如下:
    1、网络环境:运营商网络、主机网卡的traffic、Nginx网关总请求耗时、Nginx后端请求耗时;
    2、主机性能:CPU使用率、Load最近1分钟情况、内存使用率、内存剩余容量、磁盘使用量和剩余比例、磁盘IO速率;
    3、服务性能:业务相关的QPS与TPS、线程空闲比例、线程队列大小、old区GC情况。

  • 相关阅读:
    Console.WriteLine输出字符格式化
    GridView动态生成列问题
    日历控件,可运行在XHTML1.0下
    GridView內容導出Excel時異常:必须置於有 runat=server 的表单标记之中
    圆弧分割
    矩阵变换
    使用group by 来统计的小作业
    group by 后使用 rollup 子句总结
    mysql字符串拼接,存储过程,(来自网上看到)
    【深入理解Linux内核】《第二章 内存寻址》笔记 (2014-06-28 12:38)
  • 原文地址:https://www.cnblogs.com/evakang/p/12863966.html
Copyright © 2011-2022 走看看