一、pushgateway的作用
傳統監控軟件如Zabbix通常都建議使用push的方式來由客戶端推送數據給服務端,這樣可以減輕服務端壓力。但是這樣也有個弊端就是配置更為復雜,需要在每個agent上都配置server的地址才可以感知到server的存在。雖然Prometheus默認已經是采用pull的方式來主動拉取數據,但是在某些情況下還是會使用更靈活的push方式,比如需要監控的項目生命周期很短,需要主動上報數據給服務端,這個時候就可以使用Prometheus的pushgateway來實現push方式的監控。Prometheus不再需要自己去拉取數據,而是讓用戶通過自定義的Shell腳本把需要的數據發送給pushgateway,然后再由pushgateway推送數據給Prometheus。pushgateway是可以單獨運行在任何節點上的插件,不一定要在被監控客戶端上。
二、配置pushgateway方式監控
1、在Prometheus官網下載pushgateway組件。下載地址是https://prometheus.io/download/
2、將壓縮包解壓並運行pushgateway程序,默認會監聽在9091端口
./pushgateway
3、修改prometheus的配置文件,給pushgateway定義一個job
-job_name: 'pushgateway_test' #這個名稱可以自定義,后面會用到
static_configs:
- targets: ['192.168.100.110:9091'] #這里是pushgateway的地址
4、自定義腳本采集數據,這里以監控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則是指定機器名,使用的就是腳本里獲取的那個變量值
5、將腳本加入到計划任務中,定時推送數據,如果希望監控時長小於一分鍾,可以使用sleep方法
6、在Prometheus界面使用自定義的key獲取數據測試

版權聲明
本站所有文章均為原創,轉載請注明出處!小站維護不易,如果對您有所幫助,希望能點擊一下站內廣告,謝謝!
