grafana介绍
Grafana 是一个开源的度量分析和可视化工具 ,可以通过将采集的数据分析 ,查询 ,然后进行可视化的展示 ,并能实现报警。
grafana安装与登录
在grafana服务器上安装grafana
下载地址:https://grafana.com/grafana/download (请使用共享的软件版本,以免出现不兼容问题)
拷贝软件包到grafana服务器上安装
bash
[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_64
urw-fonts is needed by grafana-6.4.2-1.x86_64
# 依次安装
[root@grafana ~]# yum -y install fontconfig freetype urw-fonts
再次进行安装
bash
[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 systemd
sudo /bin/systemctl daemon-reload
sudo /bin/systemctl enable grafana-server.service
### You can start grafana-server by executing
sudo /bin/systemctl start grafana-server.service
POSTTRANS: Running scrip
启动grafana,并验证端口
bash
[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
示例:
有兴趣的可以下载几个尝试一下(不一定版本兼容,如果不兼容,可多试几个不同版本)