python - scrapy-redis,爬取全部url结束,不需要清空redis,已设置SCHEDULER_PERSIST = True。

查看:781
本文介绍了python - scrapy-redis,爬取全部url结束,不需要清空redis,已设置SCHEDULER_PERSIST = True。的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

  1. 使用scrapy-redis,已设置SCHEDULER_PERSIST = True,爬取结束后,仍自动清空redis库。

  2. 清空redis库,不会自动停止爬取,仍在一直请求。

  3. 我是使用一个种子库,用master插入请求的url,slave读取source:start_urls,未使用scrapy-reids自动插入url到redis。

  4. 运行了一下scrapy-redis里面的example-project,lpush了一个url,使用scrapy crawl myspider_redis,发现也是不能自动结束,一直空跑。

  5. settings设置如下:

SPIDER_MODULES = ['market.spiders']
NEWSPIDER_MODULE = 'market.spiders'


DUPEFILTER_CLASS = "scrapy_redis.dupefilter.RFPDupeFilter"
SCHEDULER = "scrapy_redis.scheduler.Scheduler"
SCHEDULER_QUEUE_CLASS = "scrapy_redis.queue.SpiderPriorityQueue"
SCHEDULER_PERSIST = True

DOWNLOADER_MIDDLEWARES = {
    'market.middleware.UserAgentMiddleware': 401,
    'scrapy.downloadermiddlewares.redirect.RedirectMiddleware': 400,
    'market.redirect_middleware.Redirect_Middleware':500,

}

ITEM_PIPELINES = {
    'market.pipelines.MarketPipeline': 300,
    'scrapy_redis.pipelines.RedisPipeline': 301,
}

LOG_LEVEL = 'DEBUG'

# Introduce an artifical delay to make use of parallelism. to speed up the
# crawl.
DOWNLOAD_DELAY = 1
COMMANDS_MODULE = 'market.commands'

#redis
REDIS_HOST = '127.0.0.1'
REDIS_PORT = 6379

解决方案

  • 解决url取完,继续空跑,可以参考这个解决空跑

  • 或者在 scrapy-redis/spider的next_requests加入:

if found == 0:
    self.crawler.engine.close_spider('queue is empty, the spider close')

这篇关于python - scrapy-redis,爬取全部url结束,不需要清空redis,已设置SCHEDULER_PERSIST = True。的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆