使用scrapy-redis实现分布式爬虫

一、准备工作

用来实现分布式爬虫的项目是:爬取知乎用户信息项目
注册了两个服务器:阿里云服务器和腾讯云服务器,使用的系统都是windows系统

二、scrapy-redis组件的使用

知乎用户项目下载至本地,并使用git命令新建分支以方便对项目进行更改而不影响之前的项目:

git checkout -b distributed #新建分支
git branch #切换分支

在项目settings.py中加入:

SCHEDULER = "scrapy_redis.schedler.Scheduler"
DUPEFILTER_CLASS = "scrapy_redis.dupefilter.RFPDupeFilter"
REDIS_URL = 'redis://120.xx.xx.xx:password@120.xx.xx.xx:6379' #我用的是阿里云服务器,此处包括服务器的用户名、密码、服务器公网IP、端口号
ITEM_PIPELINES = {
   'zhihuuser.pipelines.MongoPipeline': 300,
# 'scrapy_redis.pipelines.RedisPipeline': 301,
}

将更改后的项目上传至GitHub:

git add -A
git commit -m "add distributed"
git push origin distributed

三、在本机及腾讯云上进行协同爬取

在本机上可以直接使用命令运行项目:

scrapy crawl zhihu

在腾讯云服务器上需将在分支distributed上的项目克隆下来,然后再运行:

git clone http://github.com/xxx/xxx -b distributed

这样子就可以让本机及腾讯云服务器对知乎用户项目进行协同爬取,各自爬取到的数据保存在各自的MongoDB数据库–

本机MongoDB数据库:

本机MongoDB.png

腾讯云MongoDB数据库:

腾讯云MongoDB.png

阿里云redis数据库:

阿里云redis数据库.png

四、问题

在此过程中出现各种问题:
1、服务器无法进行远程连接
2、数据库无法进行远程连接
3、redis、mongodb数据库出现的报错

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值