zabbix监控haproxy

首先修改haproxy.cfg

listen  monitor_stat :8088
        stats   uri /ihaproxy-stats
        stats   realm Haproxy\ Statistics
        stats   auth ha_house:ZW5dmKRTObmOuA1nnS5U
        stats   hide-version
        bind-process    1

 

通过命令行方式获取haproxy 检测页面中各后台服务的状态

vim  /usr/local/zabbix/etc/monitor_scripts/discoverhaproxy.sh

复制代码
#!/bin/bash
portarray=(`curl -s --connect-timeout 3 -uha_house:ZW5dmKRTObmOuA1nnS6U "http://$1:8088/ihaproxy-stats;csv"|awk -F',' '{print $1,"-",$2,$18}'|sed "1,2d"|sed 's/ \- /\-/g'`)
length=${#portarray[@]}
printf "{\n"
printf  '\t'"\"data\":["
for ((i=0;i<$length;i++))
do
        printf '\n\t\t{'
        printf "\"{#SERVER_NAME}\":\"${portarray[$i]}\",\n"
        ((i+=1))
        printf '\t\t'
        printf "\"{#STATUS}\":\"${portarray[$i]}\"}"
        if [ $i -lt $[$length-1] ];then
                printf ','
        fi
done
printf  "\n\t]\n"
printf "}\n"
复制代码

 

 

vim  /usr/local/zabbix/etc/monitor_scripts/hanode.sh   该脚本是获取backend主机节点的backend名称和状态

#!/bin/bash
a=` curl -s --connect-timeout 3 -uha_house:ZW5dmKRTObmOuA1nnS6U "http://$1:8088/ihaproxy-stats;csv"|awk -F',' '{print $1,"-",$2,$18}'|sed "1,2d"|sed 's/ \- /\-/g'|grep -w $2|awk '{print $2}' `
echo $a

 

a 的值显示为:
agent_server-agent_45 UP
agent_server-agent_46 UP
agent_server-agent_47 UP
agent_server-BACKEND UP

 

zabbix键值自定义:

vim /usr/local/zabbix/etc/zabbix_agentd.conf.d/haproxy.conf

UserParameter=dishaproxy[*],/usr/local/zabbix/etc/monitor_scripts/discoverhaproxy.sh $1
UserParameter=hanode[*],/usr/local/zabbix/etc/monitor_scripts/hanode.sh $1 $2

 

 

 

查看主机的最新数据就会出现所有backend主机的状态:

转载于:https://www.cnblogs.com/hh2737/p/8257462.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Zabbix 6.0版本引入了高可用性(HA)集群的支持,使得Zabbix服务器在故障时能够继续提供服务。在搭建Zabbix 6.0 HA集群之前,你需要确保每个节点都具备以下要求: 1. 安装并配置Zabbix 6.0版本:确保每个节点上都安装了最新的Zabbix 6.0版本,并按照官方文档进行配置。 2. 数据库配置:采用高可用性数据库解决方案,例如使用PostgreSQL的流复制、MySQL的主从复制或者MariaDB的Galera Cluster等。 3. 负载均衡器:引入负载均衡器来分发请求到Zabbix服务器节点,以实现高可用性和负载平衡。常见的负载均衡器有Nginx、HAProxy等。 4. 共享存储:为了确保数据的一致性,可以使用共享存储来存储Zabbix服务器的配置文件、历史数据和监控项数据。 在具备以上要求后,你可以按照以下步骤来搭建Zabbix 6.0 HA集群: 1. 配置数据库复制:根据选择的高可用性数据库解决方案,进行相应的数据库复制配置,确保数据在节点间同步。 2. 配置负载均衡器:将负载均衡器配置为将请求分发到多个Zabbix服务器节点,以实现负载平衡和故障转移。 3. 配置共享存储:将Zabbix服务器节点的配置文件、历史数据和监控项数据存储在共享存储中,以确保数据的一致性。 4. 配置Zabbix服务器节点:在每个节点上配置Zabbix服务器,并将它们连接到共享存储和数据库。 5. 测试和监控:确保Zabbix服务器节点能够正常工作,并通过监控系统来监控整个集群的状态。 请注意,搭建Zabbix 6.0 HA集群可能涉及到复杂的配置和调优,建议参考官方文档以获取更详细的指导。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值