#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2016/10/18 9:50
# @Author : Beam
# @Site : 实现探测Web服务质量
# @File : demo_pycurl.py
# @Software: PyCharm
import pycurl
import os,sys,time
def getInfo(URL):
"""
:param URL:用户输入需要检测的URL地址
info 字典主要用于映射dic字典
dic字典主要存下curl结果
:return:没return,直接print,函数可以改写,可以用于定时检测多个域名,增加一个需要检测的url列表即可
"""
c = pycurl.Curl()
c.setopt(pycurl.URL,URL) #定义请求的URL常量
c.setopt(pycurl.CONNECTTIMEOUT,5) #请求等待时间最多5秒
c.setopt(pycurl.TIMEOUT,5) #定义请求超时时间(服务器没回应)
c.setopt(pycurl.NOPROGRESS,1) #屏蔽下载进度条
c.setopt(pycurl.FORBID_REUSE,1) #交互完成后强制断开连接,不重用
c.setopt(pycurl.MAXREDIRS,1) #指定HTTP重定向的最大数为1
c.setopt(pycurl.DNS_CACHE_TIMEOUT,30) #设置DNS信息保存时间为30秒
c.setopt(pycurl.USERAGENT,"Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/53.0.2785.116 Safari/537.36 OPR/40.0.2308.81 (Edition Baidu)")
dic = {}
info ={'NAMELOOKUP_TIME':'DNS解析时间','CONNECT_TIME':'建立连接时间','PRETRANSFER_TIME':'建立到准备传输所消耗的时间','STARTTRANSFER_TIME':'建立连接到传输开始消耗的时间','TOTAL_TIME':'传输总时间',
'HTTP_CODE':'HTTP状态码','SIZE_DOWNLOAD':'下载数据包大小','HEADER_SIZE':'HTTP头部大小','SPEED_DOWNLOAD':'平均下载速度'}
with open(os.path.dirname(os.path.realpath(__file__))+"/content.txt","wb") as indexfile:
c.setopt(pycurl.WRITEHEADER,indexfile) #将返回的HTTP HEADER定向到indexfile文件对象
c.setopt(pycurl.WRITEDATA,indexfile) #将返回的HTML内容定向到indexfile文件对象
try:
c.perform()
except Exception,e:
print "Connection error:" +str(e)
c.close()
sys.exit()
dic['NAMELOOKUP_TIME'] = '%.2f ms' % (c.getinfo(c.NAMELOOKUP_TIME)*1000) #获取DNS解析时间
dic['CONNECT_TIME'] = '%.2f ms' % (c.getinfo(c.CONNECT_TIME)*1000) #获取建立连接时间
dic['PRETRANSFER_TIME'] = '%.2f ms' % (c.getinfo(c.PRETRANSFER_TIME)*1000) #获取从建立到准备传输所消耗的时间
dic['STARTTRANSFER_TIME'] = '%.2f ms' % (c.getinfo(c.STARTTRANSFER_TIME)*1000) #获取从建立连接到传输开始消耗的时间
dic['TOTAL_TIME'] = '%.2f ms' % (c.getinfo(c.TOTAL_TIME)*1000) #获取传输总时间
dic['HTTP_CODE'] = c.getinfo(c.HTTP_CODE) #获取HTTP状态码
dic['SIZE_DOWNLOAD'] = '%d bytes/s' % (c.getinfo(c.SIZE_DOWNLOAD)) #获取下载数据包大小
dic['HEADER_SIZE'] = '%d bytes/s' % (c.getinfo(c.HEADER_SIZE)) #获取HTTP头部大小
dic['SPEED_DOWNLOAD'] = '%d bytes/s' % (c.getinfo(c.SPEED_DOWNLOAD)) #获取平均下载速度
for key in info:
print info[key],':',dic[key]
def main():
while True:
URL = raw_input("请输入一个URL地址(Q for exit):")
if URL.lower() == 'q':
sys.exit()
else:
getInfo(URL)
if __name__ == '__main__':
main()
实现探测Web服务质量
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 使用Python 2.7中pycurl模块编写探测多节点Web服务质量脚本 pycurl安装与说明 pycurl说...
- 这几天,小伙伴们的春节假期陆续结束,开始返程开工。 离家的时候,爸妈有没有给你带上家乡的土特产呀? 这几天一则新闻...
- 亲爱的~我想与你一起享受看清晨第一缕照在床上的阳光我想在你身上做,春天对樱桃树做的事我想教你电影里“色色”的东西 ...