zabbix 监控CDN带宽

简介:
1
2
3
4
5
6
7
8
9
10
        我这边使用的是网宿的CDN做加速,然后有一堆的接口可以调用单独查询;
网宿提供所有频道一起查询;cdn上面都是钱,稍微监控还是非常有必要的。
api信息格式:
https://myview.chinanetcenter.com/api/bandwidth-channel.action?u=xxxx&p=xxxx&cust=xxx&date=xxxx&channel=xxxxxx;xxxxx&isExactMatch=false&region=xxxx&isp=xxxx&resultType=xxxx&format=xxx&startdate=xxxx&enddate=xxxx
说明:
u 和p 是必选项,p是cdn后台设置的myview密码;其他可以默认或者不选;
channel:频道信息;不填默认是全部。
isp:运营商带宽;默认是所有。
startdate和enddate: 查询的时间;不选默认是全部,而这个时间也有一个规律,就是年月和时间之前用%20转码:比如(2013-01-01%2010:10就是 2013-01-01 10:10)
其api文档可以咨询客服。
1
1 、先导入bs 查看返回数据结构:
1
开始查看数据脚本:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
[root@mail python] # cat check_cndbindwaith.py 
#coding=utf-8
import  urllib,urllib2
from  bs4  import  BeautifulSoup
import  datetime
import  sys
username  =  "xxx"
password  =  "xxxx"
now_time = datetime.datetime.now()
starttime = (now_time  -  datetime.timedelta(seconds = 300 )).strftime( '%Y-%m-%d %H:%M' )
starttimeformat  =  starttime.split()[ 0 ] + "%20" + starttime.split()[ 1 ]
endtime = (datetime.datetime.now()).strftime( '%Y-%m-%d %H:%M' )
endtimtformat  =  endtime.split()[ 0 ] + "%20" + endtime.split()[ 1 ]
url  =  "https://myview.chinanetcenter.com/api/bandwidth-channel.action?u=%s&p=%s&startdate=%s&enddate=%s"  % (username,password,starttimeformat,endtimtformat)
try :
     html  =  urllib2.urlopen(url, timeout = 5 )
except  urllib2.HTTPError as err:
     print  str (err)
soup  =  BeautifulSoup(html)
print  soup
1
二、查看结果并取值:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
[root@mail python]# python check_cndbindwaith.py 
   markup_type=markup_type))
<? xml  version = "1.0"  encoding = "utf-8" ?>< html >< body >< provider  name = "ChinaNetCenter"  resulttype = "1"  type = "bandwidth-channel" >
< bandwidth  time = "2016-01-26 15:35:00" >0.00</ bandwidth >
</ channel >
</ date >
</ provider ></ body ></ html >
 
备注:我们要取的是bandwidth的值。然后通过观察发现有时候脚本返回两个值。而我们zabbix
应该只要一个返回值。
 
三、zabbix 脚本:
 
#coding=utf-8
import urllib,urllib2
from bs4 import BeautifulSoup
import datetime
import sys
def cdn():
     username = "xxx"
     password = "xxxx"
     now_time=datetime.datetime.now()
     starttime=(now_time - datetime.timedelta(seconds=300)).strftime('%Y-%m-%d %H:%M')
     starttimeformat = starttime.split()[0]+"%20"+starttime.split()[1]
     endtime=(datetime.datetime.now()).strftime('%Y-%m-%d %H:%M')
     endtimtformat = endtime.split()[0]+"%20"+endtime.split()[1]
     data = []
     url = "https://myview.chinanetcenter.com/api/bandwidth-channel.action?u=%s&p=%s&startdate=%s&enddate=%s" %(username,password,starttimeformat,endtimtformat)
     try:
         html = urllib2.urlopen(url, timeout=5)
     except urllib2.HTTPError as err:
         print str(err)
     soup = BeautifulSoup(html)
     for key in soup.find_all("bandwidth"):
         data.append(key.get_text())
     for i in data: 
         if i.startswith("0") and not i.startswith("1"):
             return 0
         else:
             return int(i.split(".")[0])
 
if __name__ == "__main__":
     print cdn()

四、zabbix agent编写脚本并且收集数据:

1
2
[root@mail scripts] # vim /usr/local/zabbix/etc/zabbix_agentd.conf
UserParameter = cdn, / usr / bin / python  / usr / local / zabbix / scripts / check_cdnbindwaitch.py

五、添加item:

wKioL1anJQOwkk-sAABddOJ9NHc598.png


六:出图和触发器根据自己需要进行添加:


wKioL1aoF0uDaToVAADRkR1uD_g562.png










本文转自 小罗ge11 51CTO博客,原文链接:http://blog.51cto.com/xiaoluoge/1738652,如需转载请自行联系原作者
相关实践学习
Serverless极速搭建Hexo博客
本场景介绍如何使用阿里云函数计算服务命令行工具快速搭建一个Hexo博客。
目录
相关文章
|
6月前
|
存储 SQL 监控
修改Zabbix源码实现监控数据双写,满足业务需求!
虽然对接Elasticsearch后有诸多好处,但是它不往数据库写历史数据了,同时还不再计算趋势数据了。有这么一个场景...
修改Zabbix源码实现监控数据双写,满足业务需求!
|
6月前
|
数据采集 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
266 4
|
11月前
|
监控 关系型数据库 机器人
小白带你学习linux的监控平台zabbix
小白带你学习linux的监控平台zabbix
263 0
|
3月前
|
监控 安全 Linux
在Linux中,zabbix如何监控脑裂?
在Linux中,zabbix如何监控脑裂?
|
1天前
|
SQL 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
15 7
|
18天前
|
JSON API 数据格式
阿里云国际版CDN查询实时带宽步骤
阿里云国际版CDN查询实时带宽步骤
|
24天前
|
SQL 监控 数据库
OceanBase社区版可以通过Zabbix监控
【10月更文挑战第5天】随着OceanBase社区版的广泛应用,企业纷纷采用这一高性能、高可用的分布式数据库系统。为了确保系统的稳定运行,使用成熟的Zabbix监控工具进行全面监控至关重要。本文通过具体示例介绍了如何配置Zabbix监控OceanBase,包括安装配置、创建监控模板和监控项、编写脚本、设置触发器及图形展示等步骤,帮助读者快速上手,及时发现并解决问题,确保业务始终处于最佳状态。
33 2
|
2月前
|
监控 关系型数据库 MySQL
zabbix agent集成percona监控MySQL的插件实战案例
这篇文章是关于如何使用Percona监控插件集成Zabbix agent来监控MySQL的实战案例。
46 2
zabbix agent集成percona监控MySQL的插件实战案例
|
3月前
|
SQL 监控 分布式数据库
【解锁数据库监控的神秘力量!】OceanBase社区版与Zabbix的完美邂逅 —— 揭秘分布式数据库监控的终极奥秘!
【8月更文挑战第7天】随着OceanBase社区版的普及,企业广泛采用这一高性能、高可用的分布式数据库。为保障系统稳定,使用成熟的Zabbix监控工具对其进行全方位监控至关重要。本文通过实例介绍如何在Zabbix中配置监控OceanBase的方法,包括创建监控模板、添加监控项(如TPS)、设置触发器及图形展示,并提供示例脚本帮助快速上手。通过这些步骤,可以有效监控OceanBase状态,确保业务连续性。
100 0
|
5月前
|
监控 数据库 Docker
Zabbix监控神通数据库教程
**摘要:** 本文介绍了如何使用Docker安装和配置神舟通用数据库,并利用Zabbix进行监控。首先,通过Docker安装数据库镜像,启动容器并映射端口。接着,使用默认凭证连接数据库并验证安装。然后,将数据库的Python模块和库文件复制到主机,并安装Python3.5及相应模块,创建外部检查脚本以实现Zabbix的监控功能。示例展示了查询数据库版本的监控指标配置。最后,提到了监控结果的界面展示,并邀请读者探索更多Zabbix监控技巧。
79 0
Zabbix监控神通数据库教程

推荐镜像

更多