#环境:CentOS Linux release 7.5.1804 (Core) mini安装,使用python2.7

#使用pucurl对输入的url地址进行测试,将结果存放到mysql中,代码来之网上收集并自行修改

#!/usr/bin/env python
# -*- coding: utf-8 -*- import MySQLdb
import os,sys
import time
import sys
import pycurl
import datetime now = datetime.datetime.now() class joincontents:
def __init__(self):
self.contents = ''
def callback(self,curl):
self.contents = self.contents + curl
#self.contents = self.contents + curl.decode('utf-8') def curlurl(url):
t = joincontents()
c = pycurl.Curl()
c.setopt(pycurl.WRITEFUNCTION,t.callback)
c.setopt(pycurl.ENCODING, 'gzip')
c.setopt(pycurl.URL,url)
c.perform() SQL_NAMELOOKUP_TIME = c.getinfo(c.NAMELOOKUP_TIME)*1000
SQL_CONNECT_TIME = c.getinfo(c.CONNECT_TIME)*1000
SQL_PRETRANSFER_TIME = c.getinfo(c.PRETRANSFER_TIME)*1000
SQL_STARTTRANSFER_TIME = c.getinfo(c.STARTTRANSFER_TIME)*1000
SQL_TOTAL_TIME = c.getinfo(c.TOTAL_TIME)*1000
SQL_HTTP_CODE = c.getinfo(c.HTTP_CODE)
SQL_SIZE_DOWNLOAD = c.getinfo(c.SIZE_DOWNLOAD)
SQL_HEADER_SIZE = c.getinfo(c.HEADER_SIZE)
SQL_SPEED_DOWNLOAD=c.getinfo(c.SPEED_DOWNLOAD) #print("HTTP状态码:%s" %(SQL_HTTP_CODE))
#print("DNS解析时间:%.2f ms"%(SQL_NAMELOOKUP_TIME))
#print("建立连接时间:%.2f ms" %(SQL_CONNECT_TIME))
#print("准备传输时间:%.2f ms" %(SQL_PRETRANSFER_TIME))
#print("传输开始时间:%.2f ms" %(SQL_STARTTRANSFER_TIME))
#print("传输结束总时间:%.2f ms" %(SQL_TOTAL_TIME))
#print("下载数据包大小:%d bytes/s" %(SQL_SIZE_DOWNLOAD))
#print("HTTP头部大小:%d byte" %(SQL_HEADER_SIZE))
#print("平均下载速度:%d bytes/s" %(SQL_SPEED_DOWNLOAD)) con = MySQLdb.connect(host="localhost", user="root", passwd="password", db="urlrecord", port=3306)
con.autocommit(1)
cur = con.cursor() try:
sql_isp_name = "ispname" sql = "insert into checkspeed (check_date, destinations_url, isp_name, http_code, namelookup_time, connect_time, \
pretransfer_time, starttransfer_time, total_time, size_down, header_size, speed_down ) \
values('%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s','%s')"% (now,url,sql_isp_name,SQL_HTTP_CODE,SQL_NAMELOOKUP_TIME, \
SQL_CONNECT_TIME,SQL_PRETRANSFER_TIME,SQL_STARTTRANSFER_TIME,SQL_TOTAL_TIME,SQL_SIZE_DOWNLOAD,SQL_HEADER_SIZE,SQL_SPEED_DOWNLOAD) cur.execute(sql)
stus = cur.fetchall() except:
import traceback
traceback.print_exc()
con.rollback()
finally:
cur.close()
con.close() if __name__ == '__main__':
for urladdress in open(r'url_list.txt').readlines():
url = urladdress.strip('\n')
curlurl(url)
#将需要测速的url地址放入url_list.txt文件中

#数据库表

CREATE TABLE `checkspeed` (
`id` int(10) NOT NULL AUTO_INCREMENT,
`check_date` datetime DEFAULT NULL,
`sources_ipaddress` varchar(15) DEFAULT NULL,
`destinations_url` varchar(100) DEFAULT NULL,
`interface_ipaddress` varchar(15) DEFAULT NULL,
`isp_name` varchar(50) DEFAULT NULL,
`http_code` varchar(3) DEFAULT NULL,
`namelookup_time` varchar(15) DEFAULT NULL,
`connect_time` varchar(15) DEFAULT NULL,
`pretransfer_time` varchar(15) DEFAULT NULL,
`starttransfer_time` varchar(15) DEFAULT NULL,
`total_time` varchar(15) DEFAULT NULL,
`size_down` varchar(15) DEFAULT NULL,
`header_size` varchar(15) DEFAULT NULL,
`speed_down` varchar(15) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1376 DEFAULT CHARSET=latin1;

Python mysql-python及pycurl使用一例的更多相关文章

  1. python/MySQL(索引、执行计划、BDA、分页)

    ---恢复内容开始--- python/MySQL(索引.执行计划.BDA.分页) MySQL索引: 所谓索引的就是具有(约束和加速查找的一种方式)   创建索引的缺点是对数据进行(修改.更新.删除) ...

  2. python mysql redis mongodb selneium requests二次封装为什么大都是使用类的原因,一点见解

    1.python mysql  redis mongodb selneium requests举得这5个库里面的主要被用户使用的东西全都是面向对象的,包括requests.get函数是里面每次都是实例 ...

  3. 10分钟教你Python+MySQL数据库操作

    欲直接下载代码文件,关注我们的公众号哦!查看历史消息即可! 本文介绍如何利用python来对MySQL数据库进行操作,本文将主要从以下几个方面展开介绍: 1.数据库介绍 2.MySQL数据库安装和设置 ...

  4. python mysql

    mysql Linux 安装mysql: apt-get install mysql-server 安装python-mysql模块:apt-get install python-mysqldb Wi ...

  5. mysql python image 图像存储读取

    最近做一些数据库调研的工作,目标是实现影像更快的入库.出库.查询,并实现并行访问等操作. 将结果总结成一个mysqlImg类. 关于mongodb的图像存储,参见http://www.cnblogs. ...

  6. MySQL Python教程(1)

    首先对于数据库的基本操作要有一定基础,其次了解Python的基础语法. 建议先阅读MysqL中文教程http://doc.mysql.cn/mysql5/refman-5.1-zh.html-chap ...

  7. Python—>Mysql—>Dbvisualizer

    MySQLdb: https://pypi.python.org/pypi/MySQL-python/1.2.4 import MySQLdb 1.Download Connector/Python: ...

  8. Python Mysql 篇

    Python 操作 Mysql 模块的安装 linux: yum install MySQL-python window: http://files.cnblogs.com/files/wupeiqi ...

  9. Nginx+uWSGI+Django+Python+ MySQL 搭建可靠的Python Web服务器

    一.安装所需工具 yum -y install gcc gcc-c++ rpm-build mysql* libtool-ltdl* libtool automake autoconf libtool ...

  10. Python MySQL ORM QuickORM hacking

    # coding: utf-8 # # Python MySQL ORM QuickORM hacking # 说明: # 以前仅仅是知道有ORM的存在,但是对ORM这个东西内部工作原理不是很清楚, ...

随机推荐

  1. 学号 20175212 《Java程序设计》第4周学习总结

    学号 20175212 <Java程序设计>第4周学习总结 教材学习内容总结 一. 子类与父类 父类中的private和友好访问权限的成员变量不会被子类继承.子类只继承父类中的protec ...

  2. 在CentOS 7 上设置返回上一级目录的快捷键为 Backspace

    参考这里. 编辑文件: $ vi ~/.config/nautilus/accels 找到这一行:  ; (gtk_accel_path "<Actions>/ShellActi ...

  3. PHP基础入门(五)---PHP面向对象实用基础知识

    前言: 今天来和大家介绍一下PHP的面向对象.说到面向对象,我不得不提一下面向过程,因为本人在初学时,常常分不清楚面向对象和面向过程,下面就来给大家介绍一下它们的区别: 面向对象专注于由哪个对象来处理 ...

  4. 前端必备之Node+mysql+ejs模版如何写接口

    前端必备之Node+mysql+ejs模版如何写接口 这星期公司要做一个视频的后台管理系统, 让我用Node+mysql+ejs配合写接口, 周末在家研究了一下, 趁还没来具体需求把研究内容在这里分享 ...

  5. PDF 补丁丁 0.6.0.3340 版发布(修复提取图片的问题)

    新的版本修复了两个导致提取图片颜色异常的问题.

  6. 第7天:Q Quant库(未完待续)

    一.本文大纲: 1.Python内置函数计算期权的价格 2.numpy加速数值计算 3.SciPy进行仿真模拟 4.SciPy求解器计算隐含波动率 5.matplotlib绘图 二.案例 (看不懂,略 ...

  7. PPT母版制作

    选择母版 首先,去iSlide官网下载iSlide,下载iSlide后,power point的菜单栏会自动出现iSilde图标(如下图). 打开iSlide这一栏,点击“图示库”,会弹出一个窗口,就 ...

  8. XE 使用记录

    project的选项是分编译版本的,debug,release,上层还有一个base 通用的设置值,最好放base里,比如Search path里 自己添加的路径,免得2个环境分别添加.

  9. Object.create()和new object()和{}的区别

    Object.create()介绍 Object.create(null) 创建的对象是一个空对象,在该对象上没有继承 Object.prototype 原型链上的属性或者方法,例如:toString ...

  10. Double H

    ##Double H Team 1.队员 王熙航211606379(队长) 李冠锐211606364 曾磊鑫211606350 戴俊涵211606359 聂寒冰211606324 杨艺勇2116063 ...