Scrapy 分布式爬取
由于受到计算机能力和网络带宽的限制,单台计算机运行的爬虫咋爬取数据量较大时,需要耗费很长时间。分布式爬取的思想是“人多力量大”,在网络中的多台计算机同时运行程序,公童完成一个大型爬取任务,
Scrapy 本身并不是一个为分布式爬取而设计的框架,但第三方库 scrapy-redis 为基扩展了分布式爬取的功能,两者结合便是一个分布式爬虫框架。在分布式怕花丛中。需要使用某种通信机制协调各个爬虫的工作,让每一份爬虫明确自己的任务,其中包括:
(1)当前的爬去任务,即下载 + 提取数据(分配任务)
(2)当前爬去任务是否已经被其他爬虫执行过(任务去重)
(3)如何存储爬去到的数据(数据存储)
scrapy-redis 利用 Redis 数据库作为多个爬虫数据共享实现以上功能,
1、redis 的使用
首先来学习一下 redis 数据库的使用, Redis 是一个速度非常快的费关系型数据库,使用内存为主存储,内存中的数据也可以被持久化到硬盘。Redis 以键值形式(key-value)存储数据,其中的值以分为一下 5 中类型:
(1) 字符串(string)
(2)哈希 (hash)
(3)列表(list)
(4)集合(set)
(5)有序集合(zset)
2、安装 redis
接下来安装 Redis, 在 Ubuntu 下可以 使用 apt-get 安装:
sudo apt-get installredis-server
Redis 数据库进程是一个网络服务器,可以使用一下命令开始、重启、停止 Redis:
sudo service redis-server start # 开启Redis
sudo serv\ice redis-server restart # 重启 Redis
sudo service redis-server stop # 停止 Redis
默认情况下,Redis 会在 127.0.0.1:6379 上开启服务,可以是用 netstat 命令进行查询:
netsat -ntl
3、Redis 基本命令
由于篇幅有限,这里仅介绍一些 Redis 基本使用命令,按照值的 5 种类型依次讲解
(1)字符串
Redis 的字符串(String)可以存储字符串、整数、浮点数(数字也是字符串)。String命令描述如表:
| String 命令 | 设置字符串key的值 |
| SET key value | 设置字符串 key 的值 |
| GRT key | 获取字符串 key 的值 |
| DEL key | 删除 key |
(2) 列表
Redis 的列表(List)可以有序的存储多个字符串。List 命令以及描述如图:
| List 命令 | 描 述 |
| LPUSH key value1 [value2 ... ] | 在列表 key 左端插入一个或多值 |
| RPUSH key value1 [value2 ... ] | 在列表 key 右端插入一个或多个值 |
|
LPOP key |
从列表左侧弹出一个值 |
| Rpop key | 从列表右侧弹出一个值 |
| LINDEX key index | 获取列表 key 中 index 位置的值 |
|
LRANGE key start end |
获取列表中 key 中位置【start, end】范围的值 |
| LIEN key | 获取列表中 key 的长度 |
(3)哈希
Redis 的哈希(Hash) 可以存储多个键值对,其中的键和值都是字符串,Hash 命令及描述:
| Hash 命令 | 描 述 |
| Hsah key field value | 将哈希 key 的fisld 字段赋值为 value |
|
HDEL key field [field...] |
删除哈希 key 的一个或多个字段 |
| HGET key field | 获取哈希 key 的 field 字段的值 |
| HGETALL key | 获取哈希 key 的所有字段值 |
(4)集合
Redis 集合(Set)可以存储多个唯一的字符串。Set命令及描述如图:
| Set 命令 | 描 述 |
| SADD key member1 [member2 ...] | 向集合 key 中添加一个或多个成员 |
| SREM key member1 [member2 ...] | 删除集合 key 中所有成员 |
|
SMEMBERS key |
获取集合 key 中所有成员 |
| SCRD key | 获取集合 key 中成员数量 |
| SISMEMBER key member | 判断 member是否是集合 key 的成员 |
(5)有序集合
Redis 中有序集合(ZSet)与集合(Set)类似,可以存储多个唯一的字符串,但在有序集合中,每个成员都有一个分数,所有成员按给定分数在集合中有序排列。
|
ZSet 命令 |
描 述 |
| ZADD key score1 member1 [score2 member2 ... ] | 向有序集合 key 中添加一个或多个成员 |
| ZREM member [member2... ] | 删除有序集合 key 中一个或多个成员 |
| ZRANGE key start stop | 获取有序集合 key 中位置在 [start, stop] 范围的所有成员 |
| ZRANGEBYSCORE key min max |
获取有序集合 key 中分值在[start, stop ]范围的所有成员 |
Scrapy 分布式爬取的更多相关文章
- 爬虫07 /scrapy图片爬取、中间件、selenium在scrapy中的应用、CrawlSpider、分布式、增量式
爬虫07 /scrapy图片爬取.中间件.selenium在scrapy中的应用.CrawlSpider.分布式.增量式 目录 爬虫07 /scrapy图片爬取.中间件.selenium在scrapy ...
- scrapy-redis实现爬虫分布式爬取分析与实现
本文链接:http://blog.csdn.net/u012150179/article/details/38091411 一 scrapy-redis实现分布式爬取分析 所谓的scrapy-redi ...
- scrapy关键字爬取百度图库(一)
刚入门学习python的菜鸟,如有错误,还望指教 爬取百度图库需要知道百度图库的加载方式是通过下拉加载的,所以我们需要分析Ajax请求来爬取每一页的数据信息 表述不清直接上图片 图片一是刷新页面后加载 ...
- scrapy-redis + Bloom Filter分布式爬取tencent社招信息
scrapy-redis + Bloom Filter分布式爬取tencent社招信息 什么是scrapy-redis 什么是 Bloom Filter 为什么需要使用scrapy-redis + B ...
- scrapy-redis分布式爬取tencent社招信息
scrapy-redis分布式爬取tencent社招信息 什么是scrapy-redis 目标任务 安装爬虫 创建爬虫 编写 items.py 编写 spiders/tencent.py 编写 pip ...
- scrapy分布式抓取基本设置
scrapy本身并不是一个为分布式爬取而设计的框架,但第三方库scrapy-redis为其扩展了分布式抓取的功能,在分布式爬虫框架中,需要使用某种通信机制协调各个爬虫工作 (1)当前的爬取任务,下载+ ...
- 简单的scrapy实战:爬取腾讯招聘北京地区的相关招聘信息
简单的scrapy实战:爬取腾讯招聘北京地区的相关招聘信息 简单的scrapy实战:爬取腾讯招聘北京地区的相关招聘信息 系统环境:Fedora22(昨天已安装scrapy环境) 爬取的开始URL:ht ...
- 使用scrapy框架爬取自己的博文(2)
之前写了一篇用scrapy框架爬取自己博文的博客,后来发现对于中文的处理一直有问题- - 显示的时候 [u'python\u4e0b\u722c\u67d0\u4e2a\u7f51\u9875\u76 ...
- 如何提高scrapy的爬取效率
提高scrapy的爬取效率 增加并发: 默认scrapy开启的并发线程为32个,可以适当进行增加.在settings配置文件中修改CONCURRENT_REQUESTS = 100值为100,并发设置 ...
随机推荐
- 手把手教你做一个python+matplotlib的炫酷的数据可视化动图
1.效果图 2.注意: 上述资料是虚拟的,为了学习制作动图,构建的. 仅供学习, 不是真实数据,请别误传. 当自己需要对真实数据进行可视化时,可进行适当修改. 3.代码: #第1步:导出模块,固定 i ...
- Go递归
1. 递归介绍 package main import ( "fmt" ) func test(n int) { if n > 2 { n-- test(n) } fmt.P ...
- TestNG单元测试与使用详解
TestNG的基本注解与执行顺序 在类里编辑程序时,在@Test后面,摁 alt+回车,选择对应的插件,可以把目前用到的插件自动添加到 pom.xml 文件中,如下面的testng,每摁一次,就多添加 ...
- 基于jmeter+ant实现的接口自动化测试
jmeter+ANT接口自动化测试框架 项目说明 本框架是一套基于jmeter+Ant+Excel+Python而设计的数据驱动接口自动化测试框架,jmeter 作为执行器,Ant 作为构建工具,进行 ...
- 五分钟学Java:打印Java数组最优雅的方式是什么?
在逛 Stack Overflow 的时候,发现了一些访问量像安第斯山一样高的问题,比如说这个:打印 Java 数组最优雅的方式是什么?访问量足足有 220W+,想不到啊,这么简单的问题竟然有这么多 ...
- JAVA基础学习(7)之函数
7函数 7.1函数定义与调用 7.1.1函数定义 7.1.2函数调用 package com.study.main; public class ObjectStudy { public static ...
- ACM-ICPC实验室20.2.19测试-图论
B.Harborfan的新年拜访Ⅱ 就是一道tarjan缩点的裸题. 建图比较麻烦 以后遇到这种建图,先用循环把样例实现出来,再对着循环写建图公式 #include<bits/stdc++.h& ...
- <img>标签在vue中的使用
定义和用法 onerror 事件会在文档或图像加载过程中发生错误时被触发. 在装载文档或图像的过程中如果发生了错误,就会调用该事件句柄. 实例 加载缩略图 <img :src="'/x ...
- java平衡二叉树AVL数
平衡二叉树(Balanced Binary Tree)具有以下性质:它是一棵空树或它的左右两个子树的高度差的绝对值不超过1,并且左右两个子树都是一棵平衡二叉树 右旋:在插入二叉树的时候,根节点的右侧高 ...
- Java面向对象内存图
1. java虚拟机的内存划分 2. 苹果手机类 package cn.itcast.day06.demo02; /* 定义一个类,用来模拟“手机”事物. 属性:品牌.价格.颜色 行为:打电话.发短信 ...