Python 爬虫专栏Python数据采集与爬虫爬虫进化日记

分布式爬虫笔记(二)- 多线程&多进程爬虫

2017-07-13  本文已影响327人  Spareribs

这一次分析主要是针对上 分布式爬虫笔记(一)- 非框架实现的Crawlspider 的一次改进,从单机的爬虫改成多线程和多进程爬虫~~~

多线程和多进程的区别

参考文章 单线程、多线程和多进程的效率对比测试

1 多线程核心点说明

这一次对爬虫代码的修改其实主要是getQueneURL和start_crawl函数函数的处理。(建议比较难比较的小伙伴可以通过类似 git -diff 的方式来对文件进行分析)

1.1 getQueneURL函数

如果获取不到网页不做任何处理直接返回Null,这部分的处理交给theading处理那一块负责。


getQueneURKL

1.2 start_crawl函数

start_crawl

完整的代码如下,可以通过 Github 下载

2 多进程核心点说明

有兴趣的小伙伴可以通过Git -diff 将多线程和多进程两份代码对比下

3 多线程 vs 多进程对比

多线程.jpg
多线程+多进程.jpg

以上都是我的个人观点,如果有不对,或者有更好的方法,欢迎留言指正~~~

上一篇下一篇

猜你喜欢

热点阅读