scrapy的去重机制
Posted artisticmonk
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了scrapy的去重机制相关的知识,希望对你有一定的参考价值。
scrapy是通过hashlib算法转成长度一致的url,然后再通过set集合去重的,有兴趣看源码
去重的中间件在scrapy 的 dupefilters.py文件中:
--> #去重器
RFDupeFilter()
-->有个函数叫
request_seen() #被scrapy/core/scheduler.py调用
这个是调度器
scheduler.py#文件中有个函数叫enqueue_request()的函数 每来一个url就是通过这个函数来执行的
每次执行之前都会调用到 request_seen(request) 这个方法
这个方法就会生成一个指纹,指纹下面的掉用的就比较复杂了,简单的说就是要去执行 hashlib.sha1() 这个算法来生成一个固定长度的哈兮值
再然后就是在那个去重器中的
self.fingerprints = set()
就是通过上句代码执行了set集合来去重了
以上是关于scrapy的去重机制的主要内容,如果未能解决你的问题,请参考以下文章
crapy 去重与 scrapy_redis 去重与 布隆过滤器