Scrapyd部署Scrapy框架项目
  TEZNKK3IfmPf 2023年11月13日 16 0

1. scrapyd的介绍

        scrapyd是一个用于部署和运行scrapy爬虫的程序,它允许你通过JSON API(即:post请求的webapi)来部署爬虫项目和控制爬虫运行,scrapyd是一个守护进程,监听爬虫的运行和请求,然后启动进程来执行它们。

2. scrapyd的安装

  • scrapyd服务: pip install scrapyd
  • scrapyd客户端: pip install scrapyd-client

Scrapyd部署Scrapy框架项目

Scrapyd部署Scrapy框架项目

3. 启动scrapyd服务

  1. 在scrapy项目路径下 启动scrapyd的命令:sudo scrapyd 或 scrapyd

  2. 启动之后就可以打开本地运行的scrapyd,浏览器中访问本地6800端口可以查看scrapyd的监控界面

Scrapyd部署Scrapy框架项目

Scrapyd部署Scrapy框架项目

 

 

  • 点击job查看任务监控界面

Scrapyd部署Scrapy框架项目

 

4. scrapy项目部署

4.1 配置需要部署的项目

        编辑需要部署的项目的scrapy.cfg文件(需要将哪一个爬虫部署到scrapyd中,就配置该项目的该文件)

 [deploy:部署名(部署名可以自行定义)]
 url = http://localhost:6800/
 project = 项目名(创建爬虫项目时使用的名称)

 

Scrapyd部署Scrapy框架项目

4.2 部署项目到scrapyd

        同样在scrapy项目路径下执行:

scrapyd-deploy 部署名(配置文件中设置的名称) -p 项目名称

Scrapyd部署Scrapy框架项目

 

Scrapyd部署Scrapy框架项目

部署成功之后就可以看到部署的项目:

Scrapyd部署Scrapy框架项目

4.3 管理scrapy项目

  • 启动项目:
curl http://localhost:6800/schedule.json -d project=project_name -d spider=spider_name

Scrapyd部署Scrapy框架项目

 

Scrapyd部署Scrapy框架项目

  • 关闭爬虫:
curl http://localhost:6800/cancel.json -d project=project_name -d job=jobid

Scrapyd部署Scrapy框架项目

注意:curl是命令行工具,如果没有则需要额外安装

4.4 使用requests模块控制scrapy项目

import requests

# 启动爬虫
url = 'http://localhost:6800/schedule.json'
data = {
    'project': 项目名,
    'spider': 爬虫名,
}
resp = requests.post(url, data=data)

# 停止爬虫
url = 'http://localhost:6800/cancel.json'
data = {
    'project': 项目名,
    'job': 启动爬虫时返回的jobid,
}
resp = requests.post(url, data=data)

5. scrapyd的其他webapi

  • curl http://localhost:6800/listprojects.json (列出项目)
  • curl http://localhost:6800/listspiders.json?project=myspider (列出爬虫)
  • curl http://localhost:6800/listjobs.json?project=myspider (列出job)
  • curl http://localhost:6800/cancel.json -d project=myspider -d job=tencent (终止爬虫,该功能会有延时或不能终止爬虫的情况,此时可用kill -9杀进程的方式中止)
  • scrapyd还有其他webapi,百度搜索了解更多
【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月13日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   2024年05月31日   32   0   0 python开发语言
  TEZNKK3IfmPf   2024年05月31日   25   0   0 python
  TEZNKK3IfmPf   2024年05月31日   34   0   0 excelpython
  TEZNKK3IfmPf   2024年05月31日   25   0   0 python
TEZNKK3IfmPf