Scrapy——爬虫部署、定时任务

1.安装依赖

pip install scrapy
pip install scrapyd			# scrapyd服务
pip install scrapyd-client	# scrapyd0client 客户端
pip install spiderkeeper	# scrapy可视化部署工具

2.修改scrapyd配置

# 找到scrapyd的配置文件路径
sudo find / -name default_scrapyd.conf
  • 然后 vim 路径文件,修改以下内容:

    # 第一项是允许访问的ip,第二项是开放端口(注意云服务器记得开放安全组)
    bind_address = 0.0.0.0
    http_port   = 8868
    
  • 启动Scrapyd服务

    # 此命令为后台运行进程,并且不输入任何日志
     nohup scrapyd >/dev/null 2>&1 &
    
  • 浏览器输入x.x.x.x:8868,测试是否成功
    Scrapy——爬虫部署、定时任务_第1张图片

3.使用SpiderKeeper部署爬虫

  • 启动SpiderKeeper服务,scrapyd需提前启动

     spiderkeeper --server=http://x.x.x.x:8868
    
  • 测试是否成功,浏览器访问x.x.x.x:5000
    默认端口为5000,默认账号密码皆为admin,可在依赖路径下的config.py文件中更改(/software/anaconda3/lib/python3.7/site-packages/SpiderKeeper)
    Scrapy——爬虫部署、定时任务_第2张图片

  • 修改爬虫项目中的scrapy.cfg文件配置
    在这里插入图片描述

  • 你的scrapy爬虫项目下执行命令scrapyd-deploy --build-egg output.egg

    scrapyd-deploy --build-egg output.egg
    

    这里可能遇到问题:No module named ‘scrapy.util.http’
    Scrapy——爬虫部署、定时任务_第3张图片
    这是由于底层scrapyd-deploy的模块scrapy.utils.http已经弃用,建议更新为w3lib.http替代,进入该路径,编辑为以下内容:
    Scrapy——爬虫部署、定时任务_第4张图片
    重新执行命令,如果成功,会出现以下内容:
    在这里插入图片描述
    Scrapy——爬虫部署、定时任务_第5张图片

  • 将output.egg文件下载到本地

  • 在SpiderKeeper上创建项目,点击deploy
    Scrapy——爬虫部署、定时任务_第6张图片

  • 上传之前下载到本地的output.egg,然后submit
    Scrapy——爬虫部署、定时任务_第7张图片

  • 点击Periodic Jobs设置定时任务
    Scrapy——爬虫部署、定时任务_第8张图片

你可能感兴趣的:(python,scrapy)