在阿里云服务器使用scrapyd部署scrapy项目

本文涉及的产品
云数据库 Redis 版,标准版 2GB
推荐场景:
搭建游戏排行榜
云原生内存数据库 Tair,内存型 2GB
简介: 前言分布式爬虫,总归是要上到服务器的。这里先讲解如何在服务器上配置和部署scrapyd,主要的点还是在scrapyd和redis的conf配置文件上。

前言

分布式爬虫,总归是要上到服务器的。

这里先讲解如何在服务器上配置和部署scrapyd,主要的点还是在scrapyd和redis的conf配置文件上。其实到末尾我已经实现了分布式,本机的爬虫访问远程redis,从里面拿数据,但是由于是测试,没有放入start_urls,所以也没有启动并爬出结果,但是redis远程连接确实是做到了。下一篇结合Docker再搭建分布式爬虫。


环境配置

为了从头配置,我在阿里云上重新更换了纯净的Centos7.4,新盘,什么都没有。

创建环境

这里比较简单,参考自己写的《Aliyun-安装Anaconda记录 》就可以成功安装Anaconda了

创建环境的话用命令:

conda create --name pspiders python=3.6

创建一个名为pspiders并且版本是python3.6的虚拟环境。

进入环境的命令:

source activate pspiders

当前面出现(pspiders)

(pspiders) [root@iZqmg63rkase8aZ SRspider]# 

就代表着成功进入了虚拟环境。


安装scrapyd

首先,通过本地sftp将写好的代码上传到服务器,我这里是新建目录SRspider,然后将代码上传到目录中。

然后cd进入SRspider目录,与.cfg文件同目录内,通过命令开启虚拟环境:

source activate pspiders

然后安装scrapyd以及scrapd-client

(pspiders) [root@ixxx SRspider]#  pip install scrapyd

(pspiders) [root@ixxx SRspider]#  pip install scrapyd-client

这样就完成了他们的安装。

导入环境依赖

接着导入本地机器的依赖包,在本地的虚拟环境下,通过命令导出requirements.txt:

pip freeze > requirements.txt

就会在当前目录下生成此文件,打开后将文件内容复制,并在服务器的虚拟环境下vim新建同名文件,写入内容(刚才导出的文件内容):

six==1.11.0
Twisted==17.9.0
urllib3==1.22
w3lib==1.18.0
you-get==0.4.1011
zope.interface==4.4.3
……
……
……

这里面记录的就是之前的虚拟环境的依赖,如果不导入的话,就要手动在虚拟环境下通过pip安装这些依赖(建议导入)。

然后在服务器通过命令:

pip install -r requirements.txt

安装依赖,可以看到它依次下载并安装。


服务器安装redis

这个比较简单:

yum install redis

跟着提示就行了,然后用命令启动redis:

service redis start

设置为开启启动的话:

chkconfig redis on

配置scrapyd远程访问

到这里,scrapyd也安装好了、依赖也装好了、代码也上传了、redis也安装好了,是不是可以打包然后就开启scrapyd服务了呢?

当初我也是这么认为的,直到scrapyd启动服务后,在浏览器打开http://59.110.xxx.xxx:6800,但是始终无法访问,这个问题困扰了很久,后来在群里面有人告诉我应该开启阿里云安全组配置(我去检查了,我已经开启6800端口),又有人说scrapyd默认绑定地址是127.0.0.1,要将它绑定的地址改为0.0.0.0就可以开启外部访问了。文件路径是在:

/root/anaconda3/envs/pspiders/lib/python3.6/site-packages/scrapyd

下面有一个default_scrapyd.conf 文件,vi打开后找到里面有一句:

bind_address = 127.0.0.1

将它改成0.0.0.0保存,就可以远程访问了。

这时候到SRspider目录下打开虚拟环境,然后输入命令scrapyd启动它,再用浏览器打开就可以访问到了。

配置redis远程访问

redis同样,默认设定是本地访问,如果想开启远程访问就要改动bind

但是为了安全起见(redis默认没有密码,开启远程后别人可以操作),就需要给redis设置密码,通过命令redis-cli启动redis的命令行:

[root@iZqmg63rkase8aZ scrapyd]# redis-cli
127.0.0.1:6379> 

然后查看是否有密码:

127.0.0.1:6379> config get requirepass
1) "requirepass"
2) ""
127.0.0.1:6379> 

如果是密码为空,则需要设置密码:

CONFIG set requirepass "ranbos"

再次查看的时候就会提示需要密码:

(error) NOAUTH Authentication required.

用命令登录:

auth ranbos

即可登录。这里就完成了密码的设置,通过命令quit退出命令行。下面更改bind

进入redis.conf目录下(默认在/etc下):

 cd /etc

然后用ls查看目录下的文件,发现有redis.conf文件

输入图片说明

用vim打开它,找到里面的bind:

bind 127.0.0.1

将它改为:

#bind 127.0.0.1
bind 0.0.0.0

我怕有错,所以先注释127.0.0.1,然后添加bind0.0.0.0

然后重启redis:

service redis restart

就可以了,redis可以远程访问了。


连接redis的代码

但是写代码的时候如何连接呢?

这里有区分master和slaver,如果是主机,就在settings.py中增加连接配置:

 # 指定redis数据库的连接参数
REDIS_HOST = "127.0.0.1"
REDIS_PORT = "6379"
REDIS_PARAMS ={
     'password': 'ranbos',
}

主机就连接本地127.0.0.1的redis就行了,写上端口号和密码。

如果是slaver端,同样是这么设置,然后将REDIS_HOST改为服务器ip即可,比如我的deepin机器就这么配置:

REDIS_HOST = "59.110.xxx.xxx"
REDIS_PORT = "6379"
REDIS_PARAMS ={
    'password': 'ranbos',
}

这样就完成了所有的配置,现在去开启服务测试。


测试

首先,在服务器上开启scrapyd服务(在项目工程.cfg同目录进入虚拟环境):

source avticate pspiders

接着开启scrapyd服务:

scrapyd

会收到如下信息:

(pspiders) [root@iZqmg63rkase8aZ SRspider]# scrapyd
2018-01-23T12:56:27+0800 [-] Loading /root/anaconda3/envs/pspiders/lib/python3.6/site-packages/scrapyd/txapp.py...
2018-01-23T12:56:27+0800 [-] Scrapyd web console available at http://0.0.0.0:6800/
2018-01-23T12:56:27+0800 [-] Loaded.
2018-01-23T12:56:27+0800 [twisted.scripts._twistd_unix.UnixAppLogger#info] twistd 17.9.0 (/root/anaconda3/envs/pspiders/bin/python 3.6.4) starting up.
2018-01-23T12:56:27+0800 [twisted.scripts._twistd_unix.UnixAppLogger#info] reactor class: twisted.internet.epollreactor.EPollReactor.
2018-01-23T12:56:27+0800 [-] Site starting on 6800
2018-01-23T12:56:27+0800 [twisted.web.server.Site#info] Starting factory <twisted.web.server.Site object at 0x7f05aea75d68>
2018-01-23T12:56:27+0800 [Launcher] Scrapyd 1.2.0 started: max_proc=4, runner='scrapyd.runner'

代表服务正常开启,服务开启后再开启一个窗口,连接到服务器。然后也是进入虚拟环境,到.cfg同目录下,打包代码,发送到:

scrapyd-deploy SRspider -p Jobbole

如果成功就会返回信息:

(pspiders) [root@iZqmg63rkase8aZ SRspider]# scrapyd-deploy SRspider -p Jobbole
Packing version 1516683538
Deploying to project "Jobbole" in http://localhost:6800/addversion.json
Server response (200):
{"node_name": "iZqmg63rkase8aZ", "status": "ok", "project": "Jobbole", "version": "1516683538", "spiders": 1}

就代表打包成功,打开页面即可看到:

输入图片说明

然后通过命令启动爬虫,开始爬取:

curl http://localhost:6800/schedule.json -d project=Jobbole -d spider=jobbole

最后通过Log可以查看到爬虫的运行情况

相关实践学习
借助OSS搭建在线教育视频课程分享网站
本教程介绍如何基于云服务器ECS和对象存储OSS,搭建一个在线教育视频课程分享网站。
7天玩转云服务器
云服务器ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,可降低 IT 成本,提升运维效率。本课程手把手带你了解ECS、掌握基本操作、动手实操快照管理、镜像管理等。了解产品详情:&nbsp;https://www.aliyun.com/product/ecs
目录
相关文章
|
29天前
|
中间件 Java 应用服务中间件
Windows部署web应用服务器Jboss中间件
如何在Windows系统上部署JBoss 7.1作为Web应用服务器,包括配置环境变量、自动部署WAR包、访问JBoss控制台、设置管理员账户以及修改端口和绑定地址等操作。
61 1
|
23天前
|
负载均衡 应用服务中间件 持续交付
微服务架构下的Web服务器部署
【8月更文第28天】随着互联网应用的不断发展,传统的单体应用架构逐渐显露出其局限性,特别是在可扩展性和维护性方面。为了解决这些问题,微服务架构应运而生。微服务架构通过将应用程序分解成一系列小型、独立的服务来提高系统的灵活性和可维护性。本文将探讨如何在微服务架构中有效部署和管理Web服务器实例,并提供一些实际的代码示例。
56 0
|
17天前
|
网络协议 网络安全
基于bind软件部署DNS服务器
关于如何使用bind软件部署DNS服务器的教程,包括DNS服务器的类型、基于bind软件的部署步骤、验证DNS服务器可用性的指导,以及如何进行DNS正向解析的实现。
18 2
基于bind软件部署DNS服务器
|
18天前
|
存储 关系型数据库 MySQL
使用Docker快速部署Mysql服务器
本文介绍了如何使用Docker快速部署MySQL服务器,包括下载官方MySQL镜像、启动容器、设置密码、连接MySQL服务器以及注意事项。
102 18
|
24天前
|
运维 数据安全/隐私保护 数据库管理
企业实战项目之服务器用户权限集中管理
企业实战项目之服务器用户权限集中管理
|
24天前
|
JavaScript NoSQL 中间件
《Node.js后端修炼手册》——揭秘服务器搭建与部署上线的生死时速,让你一战成名!
【8月更文挑战第27天】本文详细介绍如何从零开始利用Node.js构建后端服务器并部署至生产环境。首先,通过简易步骤搭建基础服务器,包括环境安装与配置。接着,引入Express框架优化路由与中间件管理,提升开发效率。随后,利用Mongoose实现MongoDB数据库连接,增强数据交互能力。为保证系统稳定性,文中还讲解了错误处理机制。最后,通过PM2等工具部署应用至生产环境,确保高效运行。本教程辅以示例代码,帮助读者快速掌握Node.js后端开发全流程。
52 2
|
26天前
|
前端开发 应用服务中间件 nginx
前端服务器部署方式
【8月更文挑战第25天】前端服务器部署方式
33 1
|
20天前
|
UED
JSF文件下载:解锁终极文件传输秘籍,让你的Web应用瞬间高大上!
【8月更文挑战第31天】掌握JSF文件下载功能对构建全面的Web应用至关重要。本文通过具体代码示例,详细介绍如何在JSF中实现文件下载。关键在于后端Bean中的文件读取与响应设置。示例展示了从创建实体类到使用`&lt;h:commandLink&gt;`触发下载的全过程,并通过正确设置响应头和处理文件流,确保文件能被顺利下载。这将显著提升Web应用的实用性与用户体验。
36 0
|
20天前
|
Java 数据库 API
JSF与JPA的史诗级联盟:如何编织数据持久化的华丽织锦,重塑Web应用的荣耀
【8月更文挑战第31天】JavaServer Faces (JSF) 和 Java Persistence API (JPA) 分别是构建Java Web应用的用户界面组件框架和持久化标准。结合使用JSF与JPA,能够打造强大的数据驱动Web应用。首先,通过定义实体类(如`User`)和配置`persistence.xml`来设置JPA环境。然后,在JSF中利用Managed Bean(如`UserBean`)管理业务逻辑,通过`EntityManager`执行数据持久化操作。
32 0
|
20天前
|
JavaScript 搜索推荐 前端开发
从零搭建到部署:Angular与Angular Universal手把手教你实现服务器端渲染(SSR),全面解析及实战指南助你提升Web应用性能与SEO优化效果
【8月更文挑战第31天】服务器端渲染(SSR)是现代Web开发的关键技术,能显著提升SEO效果及首屏加载速度,改善用户体验。Angular Universal作为官方SSR解决方案,允许在服务器端生成静态HTML文件。本文通过具体示例详细介绍如何使用Angular Universal实现SSR,并分享最佳实践。首先需安装Node.js和npm。
20 0