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中enumerate的用法实例解析
Aug 18 Python
使用graphics.py实现2048小游戏
Mar 10 Python
Django的分页器实例(paginator)
Dec 01 Python
Python实现通过继承覆盖方法示例
Jul 02 Python
Python时间和字符串转换操作实例分析
Mar 16 Python
Python字符串匹配之6种方法的使用详解
Apr 08 Python
python使用threading.Condition交替打印两个字符
May 07 Python
python异常触发及自定义异常类解析
Aug 06 Python
Python简易版停车管理系统
Aug 12 Python
使用Rasterio读取栅格数据的实例讲解
Nov 26 Python
YUV转为jpg图像的实现
Dec 09 Python
python元组打包和解包过程详解
Aug 02 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
虫族 Zerg 魔法科技
2020/03/14 星际争霸
php 调用远程url的六种方法小结
2009/11/02 PHP
PHP冒泡排序算法代码详细解读
2011/07/17 PHP
php使用ob_start()实现图片存入变量的方法
2014/11/14 PHP
9个JavaScript评级/投票插件
2010/01/18 Javascript
javascript preload&lazy load
2010/05/13 Javascript
JavaScript中最简洁的编码html字符串的方法
2014/10/11 Javascript
jquery利用拖拽方式在图片上添加热链接
2015/11/24 Javascript
JavaScript+html5 canvas制作色彩斑斓的正方形效果
2016/01/27 Javascript
精彩的Bootstrap案例分享 重点在注释!(选项卡、栅格布局)
2016/07/01 Javascript
基于原生JS实现图片裁剪
2016/08/01 Javascript
利用Vue.js实现checkbox的全选反选效果
2017/01/18 Javascript
浅谈js的解析顺序 作用域 严格模式
2017/10/23 Javascript
vue-cli 默认路由再子路由选中下的选中状态问题及解决代码
2018/09/06 Javascript
vue实现父子组件之间的通信以及兄弟组件的通信功能示例
2019/01/29 Javascript
Javascript实现一朵从含苞到绽放的玫瑰
2019/03/30 Javascript
如何在VUE中使用vue-awesome-swiper
2021/01/04 Vue.js
原生js实现自定义滚动条
2021/01/20 Javascript
Python环境下搭建属于自己的pip源的教程
2016/05/05 Python
简述:我为什么选择Python而不是Matlab和R语言
2017/11/14 Python
基于python中theano库的线性回归
2018/08/31 Python
tensorflow 只恢复部分模型参数的实例
2020/01/06 Python
PyQt5 closeEvent关闭事件退出提示框原理解析
2020/01/08 Python
在django中查询获取数据,get, filter,all(),values()操作
2020/08/09 Python
CSS3实现背景透明文字不透明的示例代码
2018/06/25 HTML / CSS
美国智能家居专家:tink
2019/06/04 全球购物
欧洲最大的预定车位市场:JustPark
2020/01/06 全球购物
代码中finally中的代码会不会执行
2012/02/06 面试题
大学生如何写自荐信
2014/01/08 职场文书
结婚喜宴主持词
2014/03/14 职场文书
企业元宵节主持词
2014/03/25 职场文书
财务会计个人原因辞职信
2019/06/21 职场文书
员工工作失职检讨书范文!
2019/07/03 职场文书
创业计划书之花店
2019/09/20 职场文书
2019年家电促销广告语集锦
2019/10/21 职场文书
SQLServer中JSON文档型数据的查询问题解决
2021/06/27 SQL Server