Python中用pycurl监控http响应时间脚本分享


Posted in Python onFebruary 02, 2015

最近需要对节点到源站自己做个监控,简单的ping可以检测到一些东西,但是http请求的检查也要进行,于是就研究了下pycurl。

pycurl是个用c语言实现的python 库,虽然据说不是那么pythonic,但是却很高效,它支持的协议居多:

supporting FTP, FTPS, HTTP, HTTPS, GOPHER, TELNET, DICT, FILE and LDAP. libcurl supports HTTPS certificates, HTTP POST, HTTP PUT, FTP uploading, kerberos, HTTP form based upload, proxies, cookies, user+password authentication, file transfer resume, http proxy tunneling and more!

这一堆协议已经很多了,我需要就是http一个,相对urlib来说,这个库可能更快些。

以下这个脚本是对某一个给定的url进行检查,并打印出http相应码,响应大小,建立连接时间,准备传输时间,传输第一个字节时间,完成时间。

#!/usr/bin/python
# coding: UTF-8
import StringIO
import pycurl
import sys
import os
class Test:
    def __init__(self):
        self.contents = ''
    def body_callback(self,buf):
        self.contents = self.contents + buf
def test_gzip(input_url):
    t = Test()
    #gzip_test = file("gzip_test.txt", 'w')
    c = pycurl.Curl()
    c.setopt(pycurl.WRITEFUNCTION,t.body_callback)
    c.setopt(pycurl.ENCODING, 'gzip')
    c.setopt(pycurl.URL,input_url)
    c.perform()
    http_code = c.getinfo(pycurl.HTTP_CODE)
    http_conn_time = c.getinfo(pycurl.CONNECT_TIME)
    http_pre_tran = c.getinfo(pycurl.PRETRANSFER_TIME)
    http_start_tran = c.getinfo(pycurl.STARTTRANSFER_TIME)
    http_total_time = c.getinfo(pycurl.TOTAL_TIME)
    http_size = c.getinfo(pycurl.SIZE_DOWNLOAD)
    print 'http_code http_size conn_time pre_tran start_tran total_time'
    print "%d %d %f %f %f %f"%(http_code,http_size,http_conn_time,http_pre_tran,http_start_tran,http_total_time)
if __name__ == '__main__':
    input_url = sys.argv[1]
    test_gzip(input_url)

脚本运行效果

xu:~/curl$ python pycurl_test.py http://daxuxu.info/
http_code http_size conn_time pre_tran start_tran total_time
200 8703 0.748147 0.748170 1.632642 1.636552

pycurl 的一些响应信息:
(参考: http://curl.haxx.se/libcurl/c/curl_easy_getinfo.html )

pycurl.NAMELOOKUP_TIME 域名解析时间
pycurl.CONNECT_TIME 远程服务器连接时间
pycurl.PRETRANSFER_TIME 连接上后到开始传输时的时间
pycurl.STARTTRANSFER_TIME 接收到第一个字节的时间
pycurl.TOTAL_TIME 上一请求总的时间
pycurl.REDIRECT_TIME 如果存在转向的话,花费的时间

pycurl.EFFECTIVE_URL
pycurl.HTTP_CODE HTTP 响应代码
pycurl.REDIRECT_COUNT 重定向的次数
pycurl.SIZE_UPLOAD 上传的数据大小
pycurl.SIZE_DOWNLOAD 下载的数据大小
pycurl.SPEED_UPLOAD 上传速度
pycurl.HEADER_SIZE 头部大小
pycurl.REQUEST_SIZE 请求大小
pycurl.CONTENT_LENGTH_DOWNLOAD 下载内容长度
pycurl.CONTENT_LENGTH_UPLOAD 上传内容长度
pycurl.CONTENT_TYPE 内容的类型
pycurl.RESPONSE_CODE 响应代码
pycurl.SPEED_DOWNLOAD 下载速度
pycurl.SSL_VERIFYRESULT
pycurl.INFO_FILETIME 文件的时间信息

pycurl.HTTP_CONNECTCODE HTTP 连接代码
pycurl.HTTPAUTH_AVAIL
pycurl.PROXYAUTH_AVAIL
pycurl.OS_ERRNO
pycurl.NUM_CONNECTS
pycurl.SSL_ENGINES
pycurl.INFO_COOKIELIST
pycurl.LASTSOCKET
pycurl.FTP_ENTRY_PATH
Python 相关文章推荐
浅谈python装饰器探究与参数的领取
Dec 01 Python
Django框架模板介绍
Jan 15 Python
python面向对象法实现图书管理系统
Apr 19 Python
Python实现平行坐标图的两种方法小结
Jul 04 Python
使用python绘制二维图形示例
Nov 22 Python
PyCharm Anaconda配置PyQt5开发环境及创建项目的教程详解
Mar 24 Python
python自动下载图片的方法示例
Mar 25 Python
python怎么判断素数
Jul 01 Python
浅谈OpenCV中的新函数connectedComponentsWithStats用法
Jul 05 Python
如何使用pycharm连接Databricks的步骤详解
Sep 23 Python
python中pow函数用法及功能说明
Dec 04 Python
Python+Tkinter制作专属图形化界面
Apr 01 Python
Python列表(list)常用操作方法小结
Feb 02 #Python
Python Sleep休眠函数使用简单实例
Feb 02 #Python
Python中实现从目录中过滤出指定文件类型的文件
Feb 02 #Python
Python实现二分法算法实例
Feb 02 #Python
Python标准异常和异常处理详解
Feb 02 #Python
Python中使用md5sum检查目录中相同文件代码分享
Feb 02 #Python
Python列表append和+的区别浅析
Feb 02 #Python
You might like
DC《神奇女侠2》因疫情推迟上映 温子仁新恐怖片《恶性》撤档
2020/04/09 欧美动漫
JAVA/JSP学习系列之二
2006/10/09 PHP
PHP时间戳使用实例代码
2008/06/07 PHP
php使用wordwrap格式化文本段落的方法
2015/03/17 PHP
Yii2中OAuth扩展及QQ互联登录实现方法
2016/05/16 PHP
PHP编程实现微信企业向用户付款的方法示例
2017/07/26 PHP
jQuery的一些注意
2006/12/06 Javascript
javascript闭包的理解和实例
2010/08/12 Javascript
BOM与DOM的区别分析
2010/10/26 Javascript
jquery中实现简单的tabs插件功能的代码
2011/03/02 Javascript
asp.net 30分钟掌握无刷新 Repeater
2011/09/16 Javascript
改变隐藏的input中value的值代码
2013/12/30 Javascript
jquery实现checkbox 全选/全不选的通用写法
2014/02/22 Javascript
JS实现CheckBox复选框全选、不选或全不选功能
2020/07/28 Javascript
jQuery中数据缓存$.data的用法及源码完全解析
2016/04/29 Javascript
JS焦点图,JS 多个页面放多个焦点图的实例
2016/12/08 Javascript
jQuery简单实现遍历单选框的方法
2017/03/06 Javascript
Javascript实现页面滚动时导航智能定位
2017/05/06 Javascript
基于Proxy的小程序状态管理实现
2019/06/14 Javascript
[01:08]DOTA2次级职业联赛 - Wings 战队宣传片
2014/12/01 DOTA
Python获取linux主机ip的简单实现方法
2016/04/18 Python
《Python学习手册》学习总结
2018/01/17 Python
Python实现PS图像调整颜色梯度效果示例
2018/01/25 Python
Python3.5实现的罗马数字转换成整数功能示例
2019/02/25 Python
聊聊python里如何用Borg pattern实现的单例模式
2019/06/06 Python
在pycharm下设置自己的个性模版方法
2019/07/15 Python
Python解析命令行读取参数之argparse模块
2019/07/26 Python
django创建简单的页面响应实例教程
2019/09/06 Python
高中军训感言200字
2014/02/23 职场文书
出纳担保书范文
2014/04/02 职场文书
公司委托书范本
2014/04/04 职场文书
我的梦中国梦演讲稿
2014/04/23 职场文书
班主任个人工作反思
2014/04/28 职场文书
旅游文化节策划方案
2014/06/06 职场文书
应急处置方案
2014/06/16 职场文书
MySQL范围查询优化的场景实例详解
2022/06/10 MySQL