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处理RSS、ATOM模块FEEDPARSER介绍
Feb 18 Python
Python全局变量操作详解
Apr 14 Python
python实现的多线程端口扫描功能示例
Jan 21 Python
Python实现图片滑动式验证识别方法
Nov 09 Python
神经网络(BP)算法Python实现及应用
Apr 16 Python
Django分页查询并返回jsons数据(中文乱码解决方法)
Aug 02 Python
Django中多种重定向方法使用详解
Jul 17 Python
python多线程扫描端口(线程池)
Sep 04 Python
详解pycharm连接不上mysql数据库的解决办法
Jan 10 Python
python自定义函数def的应用详解
Jun 03 Python
Python使用scapy模块发包收包
May 07 Python
Python排序算法之插入排序及其优化方案详解
Jun 11 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
php microtime获取浮点的时间戳
2010/02/21 PHP
Zend Studio去除编辑器的语法警告设置方法
2012/10/24 PHP
php中防止SQL注入的最佳解决方法
2013/04/25 PHP
ThinkPHP CURD方法之table方法详解
2014/06/18 PHP
Laravel 实现密码重置功能
2018/02/23 PHP
phpMyAdmin通过密码漏洞留后门文件
2018/11/20 PHP
laravel框架中路由设置,路由参数和路由命名实例分析
2019/11/23 PHP
jQuery中文入门指南,翻译加实例,jQuery的起点教程
2007/02/09 Javascript
nodejs通过phantomjs实现下载网页
2015/05/04 NodeJs
JavaScript实现定时隐藏与显示图片的方法
2015/08/06 Javascript
javascript字符串函数汇总
2015/12/06 Javascript
javascript html5实现表单验证
2016/03/01 Javascript
BootStrap智能表单实战系列(六)表单编辑页面的数据绑定
2016/06/13 Javascript
JavaScript排序算法动画演示效果的实现方法
2016/10/18 Javascript
JavaScript中的this原理及6种常见使用场景详解
2020/02/14 Javascript
Vue常用的全选/反选的示例代码
2020/02/19 Javascript
js实现弹窗效果
2020/08/09 Javascript
Python自动化构建工具scons使用入门笔记
2015/03/10 Python
用Python中的字典来处理索引统计的方法
2015/05/05 Python
Python随机读取文件实现实例
2017/05/25 Python
Python实现识别图片内容的方法分析
2018/07/11 Python
使用python绘制二维图形示例
2019/11/22 Python
Transpose 数组行列转置的限制方式
2020/02/11 Python
Python使用Selenium模拟浏览器自动操作功能
2020/09/08 Python
H5 canvas中width、height和style的宽高区别详解
2018/11/02 HTML / CSS
大韩航空官方网站:Korean Air
2017/10/25 全球购物
美国酒店控股公司:Choice Hotels
2018/06/15 全球购物
澳大利亚设计的优质鞋类和适合澳大利亚生活方式的服装:Rivers
2019/04/23 全球购物
在使用非全零作为空指针内部表达的机器上, NULL是如何定义
2014/11/09 面试题
信息管理专业学生自荐信格式
2013/09/22 职场文书
项目经理任命书内容
2014/06/06 职场文书
2015年民主生活会发言材料
2014/12/15 职场文书
2014小学语文教学工作总结
2014/12/17 职场文书
小学班主任评语
2014/12/29 职场文书
机械原理课程设计心得体会
2016/01/15 职场文书
vue 自定义的组件绑定点击事件
2022/04/21 Vue.js