分布式爬虫部署[通俗易懂]

星夢妙者
发布: 2025-09-04 08:19:24
原创
733人浏览过

大家好,又见面了,我是你们的朋友全栈君。

【服务器端】

1.下载redis ,Redis Desktop Managerredis。

2.修改配置文件(找到redis下的redis.windows.conf 双击打开,找到bind 并修改为0.0.0.0,然后 protected-mode “no”

3.打开cmd命令行 进入redis的安装目录,输入redis-server.exe redis.windows.conf 回车,保持程序一直开着。

分布式爬虫部署[通俗易懂]

如果不是这个界面,证明redis服务已经开启了,需要

redis-cli shutdown

重新输入一次redis-server.exe redis.windows.conf

4.主机开启redis服务之后,不要断开,切记!!! 进入redis安装目录,输入:redis-cli.exe -h 主机(或者别人的)ip地址(-p 端口号6379(可以不用写)),也可以直接redis-cli -h 主机ip 地址用来测试是否可以远程连接redis(如果回车之后没有出现如图效果,检查自己的bind是否修改以及redis服务是否被自己关闭)出现如下表示可以远程连接redis

分布式爬虫部署[通俗易懂]

如果想要操作数据库连接中指定数据库(默认的是数据库0),比如操作数据库5可以在命令行输入:redis-cli -h 192.168.0.1 -n 5

详情参考:Redis在命令行中操作指定数据库下的key – 简书

5在Redis Desktop Managerredis中创建连接,一定要HOST设置成本机的ip,不要是127.0.0.1,要不然分机程序一运行就会一直停顿。

6,向redis输入链接,lpush bole:start_urls 网址

模板:lpush redis_keys 网址

网易天音
网易天音

网易出品!一站式音乐创作工具!零基础写歌!

网易天音 76
查看详情 网易天音
分布式爬虫部署[通俗易懂]

爬虫端部署】

爬虫分两种流派,一种是有规则的,一种是无规则的。运行方式各有不通。

共同点:setting.py

代码语言:javascript代码运行次数:0运行复制
<pre class="brush:php;toolbar:false;">LOG_LEVEL='DEBUG'USER_AGENT = 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.132 Safari/537.36'# Crawl responsibly by identifying yourself (and your website) on the user-agent#USER_AGENT = 'dushu_redis (+http://www.yourdomain.com)'#配置去重DUPEFILTER_CLASS = "scrapy_redis.dupefilter.RFPDupeFilter"#配置调度器SCHEDULER = "scrapy_redis.scheduler.Scheduler"SCHEDULER_PERSIST = True#setting.py ROBOTSTXT_OBEY=FalseDOWNLOAD_DELAY = 1REDIS_URL = 'redis://root:@192.168.0.105:6379/0'ITEM_PIPELINES = {    #'dushu_redis.pipelines.DushuRedisPipeline': 300,    'scrapy_redis.pipelines.RedisPipeline': 400,}
登录后复制

(1)【有规则的爬虫】这里一定要开启爬虫过滤 ,否则在有些版本,无法过滤

def make_requests_from_url(self, url): return scrapy.Request(url, dont_filter=False)

代码语言:javascript代码运行次数:0运行复制
<pre class="brush:php;toolbar:false;">import scrapyfrom scrapy.spiders import Rule#from scrapy_redis.spiders import RedisSpiderfrom scrapy.linkextractors import LinkExtractorfrom scrapy_redis.spiders import RedisCrawlSpiderclass GuoxueSpider(RedisCrawlSpider):    name = 'bole'    # start_urls = ['http://blog.jobbole.com/all-posts/']      # 添加键    redis_key = 'bole:start_urls'    rules = (        # follow all links        Rule(LinkExtractor(), callback='parse_page', follow=True),    )    def __init__(self, *args, **kwargs):        # Dynamically define the allowed domains list.        domain = kwargs.pop('domain', '')        self.allowed_domains = filter(None, domain.split(','))        super(GuoxueSpider, self).__init__(*args, **kwargs)    def make_requests_from_url(self, url):        return scrapy.Request(url, dont_filter=False)    def parse_page(self, response):        aa=response.css('title::text').extract_first()        print(aa)        return {            'name': response.css('title::text').extract_first(),            'url': response.url,        }
登录后复制

运行方式 在爬虫的根目录运行scrapy crawl 爬虫名

(2)【无规则的爬虫】

代码语言:javascript代码运行次数:0运行复制
<pre class="brush:php;toolbar:false;">from scrapy_redis.spiders import RedisSpiderclass GuoxuespiderSpider(RedisSpider):    """Spider that reads urls from redis queue (myspider:start_urls)."""    name = 'myspider'    redis_key = 'bole:start_urls'    def __init__(self, *args, **kwargs):        # Dynamically define the allowed domains list.        domain = kwargs.pop('domain', '')        self.allowed_domains = filter(None, domain.split(','))        super(GuoxuespiderSpider, self).__init__(*args, **kwargs)    def make_requests_from_url(self, url):        return scrapy.Request(url, dont_filter=False)    def parse(self, response):        aa=response.css('title::text').extract_first()        print(aa)        return {            'name': response.css('title::text').extract_first(),            'url': response.url,        }
登录后复制

运行方式:

分布式爬虫部署[通俗易懂]

Redis DeskTop Manager 使用教程 – King-DA – 博客园

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/213742.html原文链接:https://javaforall.cn

以上就是分布式爬虫部署[通俗易懂]的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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