Zabbix监控阿里云SLB教程

本文介绍如何使用Zabbix监控阿里云SLB 阿里云负载均衡(Server Load Balancer,简称SLB)是云原生时代应用高可用的基本要素。通过将流量分发到不同的后端服务来扩展应用系统的服务吞吐能力,消除单点故障并提升应用系统...

1.SLB介绍

里云负载均衡(Server Load Balancer,简称SLB)是云原生时代应用高可用的基本要素。通过将流量分发到不同的后端服务来扩展应用系统的服务吞吐能力,消除单点故障并提升应用系统的可用性。 阿里云SLB包含面向4层的网络型负载均衡NLB、面向7层的应用型负载均衡ALB和传统型负载均衡CLB,是阿里云官方云原生网关。

2.监控前准备

本次监控方式通过zabbix采集器方式(目前网上能查到的文章,监控数据获取是基于agent的。由于调用阿里云的接口,超过一定次数会有费用产生,故采用采集器方式会比agent更优

3.获取SLB实例

#!/usr/bin/env python
#coding=utf-8
from aliyunsdkcore.client import AcsClient
from aliyunsdkcore.acs_exception.exceptions import ClientException
from aliyunsdkcore.acs_exception.exceptions import ServerException
from aliyunsdkcore.auth.credentials import AccessKeyCredential
from aliyunsdkcore.auth.credentials import StsTokenCredential
from aliyunsdkslb.request.v20140515.DescribeLoadBalancersRequest import DescribeLoadBalancersRequest
import json
# 这里填 ACCESS_KEY 和SECRET_KEY
credentials = AccessKeyCredential('*********', '***************')
# use STS Token
# credentials = StsTokenCredential('<your-access-key-id>', '<your-access-key-secret>', '<your-sts-token>')
# 这里填资源所属区域
client = AcsClient(region_id='cn-hangzhou', credential=credentials)
request = DescribeLoadBalancersRequest()
request.set_accept_format('json')
response = client.do_action_with_exception(request)
res = json.loads(response)
r = []
# 拼接成用于zabbix自动发现资源的格式 ,这里使用  LoadBalancerId 作为主机名称   LoadBalancerName 作为可见名称
for i in res['LoadBalancers']['LoadBalancer']:
        buf = {'{#PROJECT}':'acs_slb_dashboard', '{#INSTANCE}':i['LoadBalancerId'], '{#INSTANCE_NANME}':i['LoadBalancerName']}
        r.append(buf)
print(json.dumps({"data":r}))

4.获取监控数据

#!/usr/bin/env python
#coding=utf-8
from aliyunsdkcore.client import AcsClient
from aliyunsdkcore.acs_exception.exceptions import ClientException
from aliyunsdkcore.acs_exception.exceptions import ServerException
from aliyunsdkcore.request import CommonRequest
from aliyunsdkcore.auth.credentials import AccessKeyCredential
from aliyunsdkcore.auth.credentials import StsTokenCredential
from aliyunsdkcms.request.v20190101.DescribeMetricLastRequest import DescribeMetricLastRequest
import json,sys
from os import popen,system
# 键值
k=sys.argv[1]
# 资源所在区域
Produce=sys.argv[2]
# 命名空间
Namespace=sys.argv[3]
# ACCESS_KEY
Akey=sys.argv[4]
# SECRET_KEY
Skey=sys.argv[5]
# 获取监控数据的数据类型,有最大值(Maximum),平均值(avg)等
Kdata=sys.argv[6]
#zabbix_sender 绝对路径
ZABBIX_SEND_ADDR = '/itops/zabbix/bin/zabbix_sender'     
#zabbix_server或zabbix_proxy地址,用于接收数据
zabbix_server_ip = "192.168.1.1"   
#zabbix_server或zabbix_proxy服务端口
ZABBIX_PORT = '10051'      
credentials = AccessKeyCredential(Akey, Skey)
    # use STS Token
    # credentials = StsTokenCredential('<your-access-key-id>', '<your-access-key-secret>', '<your-sts-token>')
client = AcsClient(region_id=Produce, credential=credentials)
request = DescribeMetricLastRequest()
request.set_accept_format('json')
request.set_Namespace(Namespace)
request.set_MetricName(k)
result = client.do_action_with_exception(request)
#res = response.decode()
result = json.loads(result)
result = json.loads(result['Datapoints'])
#print(result)
# 通过zabbix_sender 发送监控数据到监控对象
for i in result:
        hosthost=i["instanceId"]
        key=k
        value=i[Kdata]
        popen('%s -z %s -p %s -s %s -k %s -o %s >/dev/null' % (ZABBIX_SEND_ADDR,zabbix_server_ip,ZABBIX_PORT,"'" + hosthost + "'","'" + key + "'","'" + str(value) + "'"))

5.监控模板制作

新增自动发现规则用于自动发现SLB实例

FZBQc0kS63c5197303a6e.png

新增监控项,用于获取监控数据

QzvBLzmY63c519889052a.png

新增监控数据接收的监控模板

VsSzNnid63c519a79f6c2.png

6.指标清单参考

https://cms.console.aliyun.com/metric-meta/acs_slb_dashboard/slb?spm=a2c4g.11186623.0.0.68a46c8aTDUUGP



你可能感兴趣的文章

相关问题

0 条评论

请先 登录 后评论
细雨闲花
细雨闲花

11 篇文章

作家榜 »

  1. 乐维君 350 文章
  2. YOHOHO 14 文章
  3. 机灵小和尚 13 文章
  4. 我是一只小菜鸡 12 文章
  5. 细雨闲花 11 文章
  6. 御前侍卫张五哥 9 文章
  7. 。。。 8 文章
  8. 小黄人 8 文章