[Gevent]gevent 网络抓取问答
2015-07-02 11:05
531 查看
我听说过gevent基于事件的异步处理功能 如何高效率,该项目已很少使用,今天是没什么学习一些简单的使用。
有正式书面一个非常好的教程 中国版的地址:http://xlambda.com/gevent-tutorial/ 学习gevent非常不错的资料。
详细的理论这里不怎么说了,仅仅是有些了解。详细的原理还不能解释的非常清楚。
只是协程这样的概念在golang里面非常多。
写了一个訪问网络,使用同步操作,gevent 和 多线程对照的样例。
这结果仅仅能作为參考。由于不同的时间网络状况有差异,可是总的来说多线程最快。gevent还行,同步最慢。
可是考虑到gevent的开销非常小。所以还是非常具有性价比的。
还有从结果中能够看到gevent和多线程都会有上下文切换,所以运行结果的线程id是乱序的,这个非常好理解。
有正式书面一个非常好的教程 中国版的地址:http://xlambda.com/gevent-tutorial/ 学习gevent非常不错的资料。
详细的理论这里不怎么说了,仅仅是有些了解。详细的原理还不能解释的非常清楚。
只是协程这样的概念在golang里面非常多。
写了一个訪问网络,使用同步操作,gevent 和 多线程对照的样例。
#!/usr/bin/python # -*- coding: utf-8 -*- # python2.7x # gevent_urllib2.py # author: orangelliu # date: 2014-08-20 import gevent.monkey gevent.monkey.patch_socket() import gevent import urllib2 import json import threading def fetch(pid): response = urllib2.urlopen('http://www.orangleliu.info') result = response.read() btypes = len(result) print 'process %s : %s'%(pid, btypes) def synchronous(): for i in range(10): fetch(i) def asynchonous(): threads = [] for i in range(10): threads.append(gevent.spawn(fetch,i)) gevent.joinall(threads) def mulithread(): threads = [] for i in range(10): th = threading.Thread(target=fetch, args=(i,)) threads.append(th) for thread in threads: thread.start() for thread in threads: threading.Thread.join(thread) import time print 'sync....' ss = time.time() synchronous() print 'sync time is %s'%(time.time()-ss) print 'async' sa = time.time() asynchonous() print 'async time is %s'%(time.time()-sa) print 'async' sm = time.time() mulithread() print 'thread time is %s'%(time.time()-sm)
这结果仅仅能作为參考。由于不同的时间网络状况有差异,可是总的来说多线程最快。gevent还行,同步最慢。
可是考虑到gevent的开销非常小。所以还是非常具有性价比的。
还有从结果中能够看到gevent和多线程都会有上下文切换,所以运行结果的线程id是乱序的,这个非常好理解。
sync.... process 0 : 8657 process 1 : 8657 process 2 : 8657 process 3 : 8657 process 4 : 8657 process 5 : 8657 process 6 : 8657 process 7 : 8657 process 8 : 8657 process 9 : 8657 sync time is 2.7610001564 async process 8 : 8657 process 7 : 8657 process 6 : 8657 process 2 : 8657 process 5 : 8657 process 3 : 8657 process 0 : 8657 process 4 : 8657 process 1 : 8657 process 9 : 8657 async time is 1.50199985504 async process 0 : 8657 process 1 : 8657 process 3 : 8657 process 4 : 8657 process 5 : 8657 process 7 : 8657 process 9 : 8657 process 8 : 8657 process 6 : 8657 process 2 : 8657 thread time is 0.986000061035本文出自 “orangleliu笔记本” 博客,请务必保留此出处/article/2588674.html
相关文章推荐
- iOS开发中HTTP协议的应用
- tableViewCell的网络图片加载方法
- Http协议
- TCP实现客户端和服务器的通信
- 查看网络图片
- 无线网络模式和加密方式简介
- 查看网络图片
- Python网络爬虫之网盘爬虫【简易版】
- 网络基础(2)--通信过程之一HTTP协议
- 《UNIX网络编程》卷I 实验环境搭建
- iOS开发网络篇—使用ASI框架进行文件下载
- iOS开发之runtime的运用-获取当前网络状态
- Android Http编程之HttpClient
- 构建自己的AngularJS,第一部分:作用域和digest 转摘:http://www.ituring.com.cn/article/39865
- 解决Unable to update index for central|http://repo1.maven.org/maven2错误
- Linux下tcp并发服务器的几种设计的模式套路
- iOS开发工具-网络封包分析工具Charles
- Linux内核软RPS实现网络接收软中断的负载均衡分发
- 网络基础篇(一)--TCP/IP协议族
- 【C语言】模拟实现库函数srtcpy函数