Zabbix使用Pycurl模块监控web页面状态

简介:

由于网络的问题,zabbix自带web模块用不了,后台研发2b,老是更新正式环境安装包,导致一直出问题,老是给他们擦屁股,早说过这事,他们不配合,现在出问题了,挺爽j_0025.gif,这锅我表示不背,就找了pycurl这个模块写个监控。


pycurl模块用法:

(这块是抄的j_0023.gif,引用地址:http://blog.csdn.net/xsj_blog/article/details/52102652)

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
c = pycurl.Curl()     #创建一个curl对象 
c.setopt(pycurl.CONNECTTIMEOUT, 5)     #连接的等待时间,设置为0则不等待  
c.setopt(pycurl.TIMEOUT, 5)            #请求超时时间  
c.setopt(pycurl.NOPROGRESS, 0)         #是否屏蔽下载进度条,非0则屏蔽  
c.setopt(pycurl.MAXREDIRS, 5)          #指定HTTP重定向的最大数  
c.setopt(pycurl.FORBID_REUSE, 1)       #完成交互后强制断开连接,不重用  
c.setopt(pycurl.FRESH_CONNECT,1)       #强制获取新的连接,即替代缓存中的连接  
c.setopt(pycurl.DNS_CACHE_TIMEOUT,60)  #设置保存DNS信息的时间,默认为120秒  
c.setopt(pycurl.URL, "http://www.baidu.com" )       #指定请求的URL  
c.setopt(pycurl.USERAGENT, "Mozilla/5.2 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322; .NET CLR 2.0.50324)" )     #配置请求HTTP头的User-Agent
c.setopt(pycurl.HEADERFUNCTION, getheader)    #将返回的HTTP HEADER定向到回调函数getheader
c.setopt(pycurl.WRITEFUNCTION, getbody)       #将返回的内容定向到回调函数getbody
c.setopt(pycurl.WRITEHEADER, fileobj)         #将返回的HTTP HEADER定向到fileobj文件对象
c.setopt(pycurl.WRITEDATA, fileobj)           #将返回的HTML内容定向到fileobj文件对象
c.getinfo(pycurl.HTTP_CODE)          #返回的HTTP状态码
c.getinfo(pycurl.TOTAL_TIME)         #传输结束所消耗的总时间
c.getinfo(pycurl.NAMELOOKUP_TIME)    #DNS解析所消耗的时间
c.getinfo(pycurl.CONNECT_TIME)       #建立连接所消耗的时间
c.getinfo(pycurl.PRETRANSFER_TIME)   #从建立连接到准备传输所消耗的时间
c.getinfo(pycurl.STARTTRANSFER_TIME)     #从建立连接到传输开始消耗的时间
c.getinfo(pycurl.REDIRECT_TIME)      #重定向所消耗的时间
c.getinfo(pycurl.SIZE_UPLOAD)        #上传数据包大小
c.getinfo(pycurl.SIZE_DOWNLOAD)      #下载数据包大小 
c.getinfo(pycurl.SPEED_DOWNLOAD)     #平均下载速度
c.getinfo(pycurl.SPEED_UPLOAD)       #平均上传速度
c.getinfo(pycurl.HEADER_SIZE)        #HTTP头部大小


代码如下:

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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#!/usr/bin/env python
# __*__coding:utf8__*__
#Author:wangpengtai
#Blog:http://wangpengtai.blog.51cto.com/
import  pycurl
import  sys
import  StringIO  #引用该模块的原因是:使用pycurl后会打印出页面内容,我们不需要看到这个内容,只需要获取页面反馈信息就行了,只能将其写入缓存中,目前没找到好办法,学艺不精,不会使用重定向写到os.devnull中,无奈初次下策。。。
#开始使用的是写入临时文件,但是会有权限问题,导致zabbix无法获取到数据。
class  WebStatus( object ):
     def  __init__( self , url):
         self .url  =  url
         self .curl  =  pycurl.Curl()
         self .string  =  StringIO.StringIO()
         # 连接等待时间,0则不等待
         self .curl.setopt(pycurl.CONNECTTIMEOUT,  5 )
         # 超时时间
         self .curl.setopt(pycurl.TIMEOUT,  5 )
         # 下载进度条,非0则屏蔽
         self .curl.setopt(pycurl.NOPROGRESS,  1 )
         # 指定HTTP重定向最大次数
         self .curl.setopt(pycurl.MAXREDIRS,  5 )
         # 完成交互后强制断开连接,不重用
         self .curl.setopt(pycurl.FORBID_REUSE,  1 )
         # 设置DNS信息保存时间,默认为120秒
         self .curl.setopt(pycurl.DNS_CACHE_TIMEOUT,  60 )
         # 设置请求的Url
         self .curl.setopt(pycurl.URL,  self .url)
         self .curl.setopt(pycurl.WRITEFUNCTION,  self .string.write) #将页面内容写入缓存
         self .curl.perform()
     def  request_value( self ):
         data  =  {
             "Http_code" self .curl.getinfo(pycurl.HTTP_CODE),
             "Speed_download" self .curl.getinfo(pycurl.SPEED_DOWNLOAD),
             "Connect_time" self .curl.getinfo(pycurl.CONNECT_TIME),
             "Total_time" self .curl.getinfo(pycurl.TOTAL_TIME),
             "Dnslookup_time" self .curl.getinfo(pycurl.NAMELOOKUP_TIME),
             "Redirect_time" self .curl.getinfo(pycurl.REDIRECT_TIME),
             "Redirect_count" self .curl.getinfo(pycurl.REDIRECT_COUNT)
         }
         return  data
     def  __end__( self ):   #释放内存和连接,做一个有始有终,有责任心的运维狗
         self .string.close()
         self .curl.close()
if  __name__  = =  "__main__" :
     Usage  =  """
Usage: python web_monitor.py url [Http_code|Speed_download|Connect_time|Total_time|Dnslookup_time|Redirect_time|Redirect_count]
     """
     try :
         url  =  sys.argv[ 1 ]
         request  =  sys.argv[ 2 ]
         try :
             =  WebStatus(url)
             try :
                 print  s.request_value()[request]
             except  KeyError:
                 print  "Make sure 2nd argument is right!"
         except  pycurl.error:
             print  "Make sure the url is right or reachable!"
     except  IndexError:
         print  "Must be 2 arguments given!%s"  %  Usage


 验证:www.baidu.com一直是我测(攻)试(击)的对象j_0038.gif

wKioL1mWn16C1FgLAADAVUbD328649.jpg-wh_50


二、配置zabbix自定义监控

这个相对来说比较灵活,可以找一台机器专门用来做监控,只需要在这台机器上配置以下内容就可以监控多个URL了。

zabbix界面中可以配置一个模版,将其挂在该机器上就行了。


1、将代码写到下面目录下并加上可执行权限

1
2
3
4
[root@zabbix-12-195 scripts] # pwd
/etc/zabbix/scripts
[root@zabbix-12-195 scripts] # vim web_monitor.py 
[root@zabbix-12-195 scripts] # chmod +x web_monitor.py


2、配置zabbix_agentd.conf

1
2
[root@zabbix-12-195 scripts] # cat /etc/zabbix_agentd.conf
UserParameter=web[*], /etc/zabbix/scripts/web_monitor .py $1 $2


3、重启zabbix-agentd

1
[root@zabbix-12-195 scripts] # service zabbix-agentd restart

三、配置zabbix监控

直接上图了,后续的添加就自由发挥了,好多返回值可以出图,可以做触发器告警等。不多叙述了j_0042.gif

wKiom1mU-YaDpLH8AAC9-gHCOUU707.jpg-wh_50

wKioL1mU-daCJY3HAACk3ML1kVk955.jpg-wh_50

wKioL1mU-iCynOqwAABiF67TeWU417.jpg-wh_50










本文转自 wangpengtai  51CTO博客,原文链接:http://blog.51cto.com/wangpengtai/1956973,如需转载请自行联系原作者
目录
相关文章
|
16天前
|
自然语言处理 Java 数据库连接
掌握JSP页面编程:动态生成Web内容
【4月更文挑战第3天】Java Server Pages (JSP) 是一种用于创建动态Web内容的Java技术,它结合HTML并允许在页面中嵌入Java代码。JSP支持代码片段、表达式语言(EL)和JSTL标签库,简化动态内容生成。当服务器接收到请求时,执行JSP中的Java代码并将结果嵌入HTML返回给客户端。示例展示了如何显示当前日期和时间。JSP可与Servlet、JavaBeans、数据库等结合,用于构建功能丰富的交互式Web应用。
掌握JSP页面编程:动态生成Web内容
|
25天前
|
机器学习/深度学习 人工智能 前端开发
机器学习PAI常见问题之web ui 项目启动后页面打不开如何解决
PAI(平台为智能,Platform for Artificial Intelligence)是阿里云提供的一个全面的人工智能开发平台,旨在为开发者提供机器学习、深度学习等人工智能技术的模型训练、优化和部署服务。以下是PAI平台使用中的一些常见问题及其答案汇总,帮助用户解决在使用过程中遇到的问题。
|
3月前
|
存储 SQL 监控
修改Zabbix源码实现监控数据双写,满足业务需求!
虽然对接Elasticsearch后有诸多好处,但是它不往数据库写历史数据了,同时还不再计算趋势数据了。有这么一个场景...
修改Zabbix源码实现监控数据双写,满足业务需求!
|
3月前
|
前端开发 开发者 UED
Web 应用中显示页面字体使用的 font-based icons 技术讲解
Web 应用中显示页面字体使用的 font-based icons 技术讲解
35 0
|
4月前
|
数据采集 监控 数据库
OceanBase社区版可以通过Zabbix监控
OceanBase社区版可以通过Zabbix监控
75 4
|
30天前
|
前端开发 JavaScript 安全
深入探索 Qt6 web模块 WebEngineCore:从基础原理到高级应用与技巧
深入探索 Qt6 web模块 WebEngineCore:从基础原理到高级应用与技巧
71 0
|
1月前
|
数据采集 监控 数据库
请问OceanBase社区版能否通过zabbix监控,然后将报错信息展现到grafana?
【2月更文挑战第25天】请问OceanBase社区版能否通过zabbix监控,然后将报错信息展现到grafana?
25 2
|
1月前
|
设计模式 前端开发 Shell
Python生成Web页面Web框架
Python生成Web页面Web框架
16 0
|
2月前
|
监控 Cloud Native 关系型数据库
使用 Grafana 统一监控展示 - 对接 Zabbix
使用 Grafana 统一监控展示 - 对接 Zabbix
|
2月前
|
JavaScript 前端开发 API
「深入探究Web页面生命周期:DOMContentLoaded、load、beforeunload和unload事件」
在 Web 开发中,了解页面生命周期是非常重要的。页面生命周期定义了页面从加载到卸载的整个过程,包括各种事件和阶段。在本文中,我们将详细介绍四个关键事件:DOMContentLoaded、load、beforeunload 和 unload。我们将探讨这些事件的属性、API、应用场景,并提供一些代码示例和参考资料。

热门文章

最新文章

推荐镜像

更多