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

Linux之grafana+onealert报警

grafana介绍

        Grafana是一个开源的度量分析和可视化工具,可以通过将采集的数据分析查询,然后进行可视化的展示,并能实现报警

grafana安装与登录 

在grafana服务器上安装grafana

下载地址:https://grafana.com/grafana/download (请使用共享的软件版本,以免出现不兼容问题)

拷贝软件包到grafana服务器上安装

[root@grafana ~]# rpm -ivh grafana-6.4.2-1.x86_64.rpm 
warning: grafana-6.4.2-1.x86_64.rpm: Header V4 RSA/SHA1 Signature, key ID 24098cb6: NOKEY
error: Failed dependencies:fontconfig is needed by grafana-6.4.2-1.x86_64     # 此时提醒需要安装三个依赖包freetype is needed by grafana-6.4.2-1.x86_64urw-fonts is needed by grafana-6.4.2-1.x86_64# 依次安装

[root@grafana ~]# yum -y install fontconfig freetype urw-fonts 

 再次进行安装

[root@grafana ~]# rpm -ivh grafana-6.4.2-1.x86_64.rpm 
warning: grafana-6.4.2-1.x86_64.rpm: Header V4 RSA/SHA1 Signature, key ID 24098cb6: NOKEY
Verifying...                          ################################# [100%]
Preparing...                          ################################# [100%]
Updating / installing...1:grafana-6.4.2-1                  ################################# [100%]
### NOT starting on installation, please execute the following statements to configure grafana to start automatically using systemdsudo /bin/systemctl daemon-reloadsudo /bin/systemctl enable grafana-server.service
### You can start grafana-server by executingsudo /bin/systemctl start grafana-server.service
POSTTRANS: Running scrip

 启动grafana,并验证端口

[root@grafana ~]# systemctl start grafana-server
[root@grafana ~]# systemctl enable grafana-server
Created symlink /etc/systemd/system/multi-user.target.wants/grafana-server.service → /usr/lib/systemd/system/grafana-server.service.
[root@grafana ~]# ss -anlt
State           Recv-Q           Send-Q                     Local Address:Port                     Peer Address:Port          Process          
LISTEN          0                128                              0.0.0.0:22                            0.0.0.0:*                              
LISTEN          0                128                                 [::]:22                               [::]:*                              
LISTEN          0                4096                                   *:3000                                *:*                              # 3000 已启动

通过浏览器访问 http:// grafana服务器IP:3000登录,使用默认的admin用户,admin密码就可以登陆了;默认用户和密码都是admin,登录进去以后会要求设置新的密码

设置prometheus为grafana数据源

把prometheus服务器收集的数据做为数据源添加到grafana,让grafana可以得到prometheus的数据  

grafana实现自定义监控cpu负载 

为添加好的数据源做图形显示

 最后在dashboard可以查看到

匹配条件显示 

 导入json模板实现mysql监控

        根据上面的思路,我们可以将mysql_global_status_threads_connected这个metrics加到
dashboard实现对mysql数据库的当前连接数的监控。
        但是mysql需要监控的状态非常的多( mysql> show status 得到的状态信息几乎都可以监控),一个个的手动添加太累了。有没有类似zabbix里的模板那种概念呢? 
        答案是有的,需要开发人员开发出相应的json格式的模板,然后导入进去就可以了。那么问题来了,谁开发?

有这么几种途径:

  • 如果公司有这方面的专业开发支持,就可以实现定制化的监控, 运维工程师配合就好
  • 当然运维工程师也可以学习并实现这方面的开发
  • 寻找别人开发好的开源项目

grafana-dashboards就是这样的开源项目

参考网址: https://github.com/percona/grafana-dashboards

1、下载grafana-dashboards开源项目

# git clone https://github.com/percona/grafana-dashboards.git

说明:学习完git与github相关课程后就明白为什么会这样下载了

2、在grafana图形界面导入相关json文件

3、导入后,刷新就有数据了(如下图所示)   

注意:导入后没有数据的请注意一下数据源的名称一定要为Prometheus(这是模板里定义好的) 

grafana+onealert报警

        prometheus报警需要使用alertmanager这个组件,而且报警规则需要手动编写(对运维来说不友好); 所以我这里选用grafana+onealert报警。 注意: 实现报警前把所有机器时间同步再检查一遍

grafana对接onealert

在onealert里添加grafana应用

官方网站: http://www.onealert.com

增加grafana应用

 配置通知策略

  在grafana增加通知通道

测试cpu负载报警

创建alert

 自定义报警规则

在被监控机上加大cpu负载(如写个死循环的shell计算脚本让其执行),然后测试报警 

 最终的邮件报警效果 

测试mysql连接数报警

创建alert

 自定义报警规则

 加大mysql连接数(可通过多个终端使用mysql命令登录模拟),然后测试报警

邮件报警结果 

总结报警不成功的可能原因 

  • 各服务器之间时间不同步,这样时序数据会出问题,也会造成报警出问题
  • 必须写通知内容,留空内容是不会发报警的
  • 修改完报警配置后,记得要点右上角的保存
  • 保存配置后,需要由OK状态变为alerting状态才会报警(也就是说,你配置保存后,就已经是alerting状态是不会报警的)
  • grafana与onealert通信有问题

 扩展

        prometheus目前还在发展中,很多相应的监控都需要开发。但在官网的dashboard库中,也有一些官方和社区开发人员开发的dashboard可以直接拿来用。

地址为:https://grafana.com/grafana/dashboards

示例:

有兴趣的可以下载几个尝试一下(不一定版本兼容,如果不兼容,可多试几个不同版本)

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 学习周报-2024.8.31
  • Tensor常见操作、自动微分及手动构建模型
  • 系统演示视频正确的录制顺序
  • 嵌入式Linux C应用编程指南-进程、线程(速记版)
  • 【SpringBoot】实体多层嵌套如何判空字段?
  • 前端面试——八股文
  • 开发中如何在运行/调试时将项目热部署到Tomcat
  • QT Sql 实现多个股票成交明细数据文件制成数据库并支持查询
  • 【AI音频处理】:重塑声音世界的无限可能
  • java JVM
  • vue3使用-watch监听总结
  • 简单易上手的生成对抗网络
  • 并发编程之JMMvolatile详解
  • watchdog: BUG: soft lockup
  • 学习笔记 ---- 数论分块(整除分块)
  • 0x05 Python数据分析,Anaconda八斩刀
  • Angular4 模板式表单用法以及验证
  • HTTP传输编码增加了传输量,只为解决这一个问题 | 实用 HTTP
  • Redis 懒删除(lazy free)简史
  • Spark in action on Kubernetes - Playground搭建与架构浅析
  • thinkphp5.1 easywechat4 微信第三方开放平台
  • 持续集成与持续部署宝典Part 2:创建持续集成流水线
  • 短视频宝贝=慢?阿里巴巴工程师这样秒开短视频
  • 关于for循环的简单归纳
  • 我的业余项目总结
  • 项目实战-Api的解决方案
  • 一、python与pycharm的安装
  • ​Spring Boot 分片上传文件
  • ​如何防止网络攻击?
  • # Apache SeaTunnel 究竟是什么?
  • #HarmonyOS:基础语法
  • %3cscript放入php,跟bWAPP学WEB安全(PHP代码)--XSS跨站脚本攻击
  • (JS基础)String 类型
  • (八)Spring源码解析:Spring MVC
  • (教学思路 C#之类三)方法参数类型(ref、out、parmas)
  • (全部习题答案)研究生英语读写教程基础级教师用书PDF|| 研究生英语读写教程提高级教师用书PDF
  • .MyFile@waifu.club.wis.mkp勒索病毒数据怎么处理|数据解密恢复
  • .NET 4.0中使用内存映射文件实现进程通讯
  • .NET 5种线程安全集合
  • .net 程序 换成 java,NET程序员如何转行为J2EE之java基础上(9)
  • .net 发送邮件
  • .net/c# memcached 获取所有缓存键(keys)
  • .net6使用Sejil可视化日志
  • .net打印*三角形
  • .net后端程序发布到nignx上,通过nginx访问
  • .net知识和学习方法系列(二十一)CLR-枚举
  • //解决validator验证插件多个name相同只验证第一的问题
  • /etc/X11/xorg.conf 文件被误改后进不了图形化界面
  • @Builder注释导致@RequestBody的前端json反序列化失败,HTTP400
  • [ Linux ] Linux信号概述 信号的产生
  • [ 网络基础篇 ] MAP 迈普交换机常用命令详解
  • [240812] X-CMD 发布 v0.4.5:更新 gtb、cd、chat、hashdir 模块功能
  • [AIGC codze] Kafka 的 rebalance 机制
  • [Algorithm][动态规划][01背包问题][目标和][最后一块石头的重量Ⅱ]详细讲解
  • [bzoj1006]: [HNOI2008]神奇的国度(最大势算法)