本站所有文章均为原创,如对您有帮助,恳请帮忙点击任何一处广告

Prometheus监控系统(4)pushgateway及自定义脚本

发布:TangLu2019-6-27 15:40分类: Prometheus 标签: Prometheus

传统的监控软件通常都建议使用push的方式,也就是让客户端来主动上报数据给服务端,这样服务端压力会比较小。但是这样也有个弊端就是配置更为复杂,需要在每个agent上都配置server的地址才可以感知到server的存在。但是某些情况下用push的方式更为灵活,所以Prometheus提供了pushgateway来实现客户端主动。Prometheus不再需要自己去拉取数据,而是让用户通过自定义的Shell脚本把需要的数据发送给pushgateway,然后再由pushgateway推送数据给Prometheus。pushgateway是可以单独运行在任何节点上的插件,不一定要在被监控客户端上。

一、在Prometheus官网下载pushgateway组件。下载地址是https://prometheus.io/download/

二、将压缩包解压并运行pushgateway程序,默认会监听在9091端口

./pushgateway


三、修改prometheus的配置文件,给pushgateway定义一个job

-job_name: 'pushgateway_test'  #这个名称可以自定义,后面会用到
  static_configs:
    - targets: ['192.168.100.110:9091']  #这里是pushgateway的地址


四、自定义脚本采集数据,这里以监控timewait的数量为例

vi count_netstat_wait_connections.sh
#!/bin/bash
instance_name=`hostname -f | cut -d'.' -f1`  #获取本机名,用于后面的的标签
label="count_netstat_wait_connections"  #定义key名
count_netstat_wait_connections=`netstat -an | grep -i wait | wc -l`  #获取数据的命令
echo "$label: $count_netstat_wait_connections"
echo "$label  $count_netstat_wait_connections" | curl --data-binary @- http://server.com:9091/metrics/job/pushgateway_test/instance/$instance_name  #这里pushgateway_test就是prometheus主配置文件里job的名字,需要保持一致,这样数据就会推送给这个job。后面的instance则是指定机器名,使用的就是脚本里获取的那个变量值


五、将脚本加入到计划任务中,定时推送数据,如果希望监控时长小于一分钟,可以使用sleep方法

六、在Prometheus界面使用自定义的key获取数据测试

pushgateway.png

温馨提示如有转载或引用以上内容之必要,敬请将本文链接作为出处标注,谢谢合作!
et_highlighter51
版权所有:《Linux运维技术学习站点
文章标题:《Prometheus监控系统(4)pushgateway及自定义脚本
除非注明,文章均为 《Linux运维技术学习站点》 原创
转载请注明本文短网址:http://www.linuxe.cn/post-506.html  [生成短网址]

已有 0/3041 人参与

发表评论:

欢迎分享Linux运维技术学习站点

欢迎使用手机扫描访问本站,还可以关注微信哦~