0

0

Scrapy中的分布式爬虫和提高数据抓取效率的方法

WBOY

WBOY

发布时间:2023-06-22 21:25:49

|

1758人浏览过

|

来源于php中文网

原创

scrapy是一个高效的python网络爬虫框架,可以快速、灵活地编写爬虫程序。然而,在处理大量数据或复杂网站时,单机爬虫可能会遇到性能和扩展问题,这时候就需要使用分布式爬虫来提高数据抓取效率。本文就介绍scrapy中的分布式爬虫和提高数据抓取效率的方法。

一、什么是分布式爬虫?

传统的单机爬虫体系结构中,所有爬虫运行在同一台机器上,面对大数据量或高压力爬取任务时,常常会出现机器性能吃紧的情况。分布式爬虫则是将爬虫任务分发到多台机器上进行处理,通过分布式计算和存储,降低了单台机器的负担,从而提高了爬虫的效率和稳定性。

Scrapy中的分布式爬虫通常使用开源的分布式调度框架Distributed Scrapy(简称DSC)来实现。DSC将Scrapy爬虫程序分发到多台机器上进行并行处理,并将结果统一汇总到中心调度节点上。

二、如何实现分布式爬虫?

1、安装Distributed Scrapy

运行以下命令安装DSC:

pip install scrapy_redis

pip install pymongo

2、修改Scrapy配置文件

在Scrapy项目的settings.py文件中添加以下配置:

使用 redis 调度器

SCHEDULER = "scrapy_redis.scheduler.Scheduler"

使用 redis 去重策略

DUPEFILTER_CLASS = "scrapy_redis.dupefilter.RFPDupeFilter"

不清空 redis 记录,可以暂停/恢复 爬取

SCHEDULER_PERSIST=True

设置redis的连接参数

REDIS_HOST='localhost'
REDIS_PORT=6379

3、编写爬虫代码

在Scrapy的爬虫程序中,需要修改起始请求的方式,使用scrapy-redis的起始方式:

encoding:utf-8

import scrapy,re,json
from ..items import DouyuItem

from scrapy_redis.spiders import RedisSpider

class DouyuSpider(RedisSpider):

# 爬虫名字
name = 'douyu'
# redis-key,从redis中pop数据进行爬取
redis_key = 'douyu:start_urls'

def parse(self, response):
    # scrapy爬虫代码

4、启动redis服务

在终端执行以下命令启动redis服务:

redis-server

MVM mall 网上购物系统
MVM mall 网上购物系统

采用 php+mysql 数据库方式运行的强大网上商店系统,执行效率高速度快,支持多语言,模板和代码分离,轻松创建属于自己的个性化用户界面 v3.5更新: 1).进一步静态化了活动商品. 2).提供了一些重要UFT-8转换文件 3).修复了除了网银在线支付其它支付显示错误的问题. 4).修改了LOGO广告管理,增加LOGO链接后主页LOGO路径错误的问题 5).修改了公告无法发布的问题,可能是打压

下载

5、启动Distributed Scrapy

在终端输入以下命令启动DSC的节点:

scrapy crawl douyu -s JOBDIR=job1

其中,job1可以是自定义名称,用于DSC记录爬虫状态。

三、优化Scrapy爬虫

Scrapy提供了许多优化爬虫效率的方法,如果配合分布式爬虫,可以进一步提高数据抓取效率。

1、使用CrawlerRunner

CrawlerRunner是需要利用一个 Twisted 的类来扩展应用程序。与简单的运行一个Python文件相比,它允许您在同一进程中同时运行多个爬虫,而无需使用多个进程或多个机器。这可以使任务管理变得更加轻松。

使用CrawlerRunner的方式如下:

from twisted.internet import reactor,defer
from scrapy.crawler import CrawlerRunner
from scrapy.utils.project import get_project_settings
from my_spider.spiders.my_spider import MySpider

runner = CrawlerRunner(get_project_settings())

@defer.inlineCallbacks
def crawl():

yield runner.crawl(MySpider)
reactor.stop()

crawl()
reactor.run()

2、降低下载中间件的优先级

如果需要在下载中间件中处理大量或复杂的数据,可以使用CONCURRENT_REQUESTS_PER_DOMAIN降低下载中间件的优先级:

CONCURRENT_REQUESTS_PER_DOMAIN = 2
DOWNLOAD_DELAY = 0.5
DOWNLOADER_MIDDLEWARES = {
'myproject.middlewares.MyCustomDownloaderMiddleware': 543,
}

3、调整CONCURRENT_REQUESTS和DOWNLOAD_DELAY参数

CONCURRENT_REQUESTS表示每个域名同时处理请求的最大数量,可以根据机器配置和任务要求合理调整。

DOWNLOAD_DELAY表示每个请求间的延迟时间,可以通过增加延迟或异步请求提高爬虫效率。

四、总结

Scrapy的分布式爬虫可以帮助我们快速处理大量数据,提高爬虫效率。同时,通过给下载中间件降低优先级、调整协程数量、增加请求延迟等方式,还可以进一步提高爬虫效率。分布式爬虫是Scrapy的重要功能之一,学会了它,可以让我们轻松应对各种爬虫任务。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

763

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

639

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

764

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

619

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1285

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

549

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

579

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

709

2023.08.11

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

23

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Python Scrapy 网络爬虫实战视频教程
Python Scrapy 网络爬虫实战视频教程

共16课时 | 5.5万人学习

CSS3 教程
CSS3 教程

共18课时 | 4.7万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号