ken桑带你读源码 之scrapy scrapycorescheduler.py

Posted gzwwj

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ken桑带你读源码 之scrapy scrapycorescheduler.py相关的知识,希望对你有一定的参考价值。

从英文来看是调度程序  我们看看是怎么调度 

  首先爬虫队列有两个 一个是保存在内存中  没有历史记录   重新开始  42行  self.mqs = self.pqclass(self._newmq)   

       另外一个是存在硬盘的队列  用于断点续传    大家看  43 行 self._dq() if self.dqdir else None     先是判断 是否有  join(jobdir, ‘requests.queue‘)  这个文件 (保存已抓取request hash)   

        然后 获取 join(self.dqdir, ‘active.json‘)    该文件是已经塞入队列但没有抓取的url     

 

      53行 def enqueue_request    塞入队列  先保存硬盘队列  然后不行 再保存内存队列    

      66行 def next_request(self):    获取队列  

 

    

以上是关于ken桑带你读源码 之scrapy scrapycorescheduler.py的主要内容,如果未能解决你的问题,请参考以下文章

ken桑带你读源码 之 scrapy_redis

一文带你读懂JDK源码:Lambda表达式

分分钟带你读懂 ButterKnife 的源码

从源码入手,一文带你读懂Spring AOP面向切面编程

从源码入手,一文带你读懂Spring AOP面向切面编程

分布式存储引擎大厂实战——带你读源码搞懂为什么Redis用单线程还这么快