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开启多个子进程并行运行的方法
Apr 18 Python
Django中对通过测试的用户进行限制访问的方法
Jul 23 Python
Python实现约瑟夫环问题的方法
May 03 Python
python中kmeans聚类实现代码
Feb 23 Python
python3个性签名设计实现代码
Jun 19 Python
Sanic框架配置操作分析
Jul 17 Python
Python使用matplotlib绘制随机漫步图
Aug 27 Python
python对列进行平移变换的方法(shift)
Jan 10 Python
使用Python做垃圾分类的原理及实例代码附源码
Jul 02 Python
在 Linux/Mac 下为Python函数添加超时时间的方法
Feb 20 Python
scrapy在python爬虫中搭建出错的解决方法
Nov 22 Python
python运算符之与用户交互
Apr 13 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
索尼ICF-SW100收音机评测
2021/03/02 无线电
PHP5 面向对象(学习记录)
2009/12/02 PHP
探讨php中遍历二维数组的几种方法详解
2013/06/08 PHP
php版微信js-sdk支付接口类用法示例
2016/10/12 PHP
PHP检测一个数组有没有定义的方法步骤
2019/07/20 PHP
php给数组赋值的实例方法
2019/09/26 PHP
JS 各种网页尺寸判断实例方法
2013/04/18 Javascript
JavaScript和CSS通过expression实现Table居中显示
2013/06/28 Javascript
javascript图片相似度算法实现 js实现直方图和向量算法
2014/01/14 Javascript
JS简单去除数组中重复项的方法
2016/09/13 Javascript
Angular2学习笔记——详解路由器模型(Router)
2016/12/02 Javascript
AngularJS控制器controller给模型数据赋初始值的方法
2017/01/04 Javascript
微信小程序图片自适应支持多图实例详解
2017/06/21 Javascript
layer父页获取弹出层输入框里面的值方法
2019/09/02 Javascript
angular共享依赖的解决方案分享
2020/10/15 Javascript
jquery自定义组件实例详解
2020/12/31 jQuery
JavaScript实现跟随鼠标移动的盒子
2021/01/28 Javascript
python 字典(dict)遍历的四种方法性能测试报告
2014/06/25 Python
Python Socket实现简单TCP Server/client功能示例
2017/08/05 Python
Python实现SQL注入检测插件实例代码
2019/02/02 Python
python Pandas如何对数据集随机抽样
2019/07/29 Python
python 实现PIL模块在图片画线写字
2020/05/16 Python
使用anaconda安装pytorch的实现步骤
2020/09/03 Python
北大研究生linux应用求职信
2013/10/29 职场文书
棉花姑娘教学反思
2014/02/15 职场文书
物业总经理岗位职责
2014/02/28 职场文书
英语一分钟演讲稿
2014/04/29 职场文书
个人委托书范本
2014/09/13 职场文书
分居协议书范本(律师见证版)
2014/11/26 职场文书
幼师大班个人总结
2015/02/13 职场文书
教师师德表现自我评价
2015/03/05 职场文书
2015年银行信贷员工作总结
2015/05/19 职场文书
2016年元旦主持词
2015/07/06 职场文书
遗嘱范文
2015/08/07 职场文书
Python如何解决secure_filename对中文不支持问题
2021/07/16 Python
Oracle中update和select 关联操作
2022/01/18 Oracle