Scrapyd部署爬蟲

Scrapyd部署爬蟲

準備工作

  • 安裝scrapyd: pip install scrapyd
  • 安裝scrapyd-client : pip install scrapyd-client
  • 安裝curl:[安裝地址](http://ono60m7tl.bkt.clouddn.com/curl.exe),安裝完成以后將所在目錄配置到環(huán)境變量中

開始部署

  1. 修改scrapy項目目錄下的scrapy.cfg文件,修改如下
[deploy:JD_Spider]    #加上target   :name
url = http://localhost:6800/   #將前面的#刪除
project = JD               #project的名字,可以使用默認的,當然也可以改變
  1. 在任意目錄下的打開終端,輸入scrapyd,觀察是否運行成功,運行成功的話,就可以打開http://localhost:6800看是否正常顯示,如果正常顯示則看到下面的這張圖,這里的JD是部署之后才能看到的,現(xiàn)在是看不到的,所以沒出現(xiàn)也不要擔心:
scrapyd
scrapyd
  1. 在項目的根目錄下運行如下的命令:python E:\python2.7\Scripts\scrapyd-deploy target -p project,這里的E:\python2.7\Scripts\是你的python安裝目錄,Scripts是安裝目錄下的一個文件夾,注意前面一定要加上python,target是在前面scrapy.cfg中設(shè)置的deploy:JD_Spider,JD_Spider就是target,project 是JD,因此這個完整的命令是python E:\python2.7\Scripts\scrapyd-deploy JD_Spider -p JD,現(xiàn)在項目就部署到上面了,這下網(wǎng)頁上就有JD了,詳情請見上圖
  1. 驗證是否成功,你可以在網(wǎng)頁上看有沒有顯示你的工程名字,另外在根目錄下輸入python E:\python2.7\Scripts\scrapyd-deploy -l就能列出你所有部署過的項目了
  1. 啟動爬蟲:curl http://localhost:6800/schedule.json -d project=myproject -d spider=spider_name,這里的project填入的是項目名,spider_name填入的是你的爬蟲中定義的name,運行我的實例完整的代碼為:curl http://localhost:6800/schedule.json -d project=JD -d spider=spider,這里將會顯示如下信息:
#這里的jobid比較重要,下面會用到這個取消爬蟲
{"status": "ok", "jobid": "3013f9d1283611e79a63acb57dec5d04", "node_name": "DESKTOP-L78TJQ7"}
  1. 取消爬蟲:curl http://localhost:6800/cancel.json -d project=myproject -d job=jobid,jobid就是上面的提到過的,如果取消我的這個實例代碼如:curl http://localhost:6800/cancel.json -d project=JD -d job=3013f9d1283611e79a63acb57dec5d04,那么它的狀態(tài)就會變成如下:
{"status": "ok", "prevstate": "running", "node_name": "DESKTOP-L78TJQ7"}
  1. 列出項目:curl http://localhost:6800/listprojects.json,下面將會出現(xiàn)你已經(jīng)部署的項目
  1. 刪除項目:curl http://localhost:6800/delproject.json -d project=myproject
  1. 列出版本:curl http://localhost:6800/listversions.json?project=myproject,這里的project是項目的名字,是在scrapy.cfg設(shè)置的
  1. 列出爬蟲:curl http://localhost:6800/listspiders.json?project=myproject這里的project是項目的名字,是在scrapy.cfg設(shè)置的
  1. 列出job:curl http://localhost:6800/listjobs.json?project=myproject這里的project是項目的名字,是在scrapy.cfg設(shè)置的
  1. 刪除版本:curl http://localhost:6800/delversion.json -d project=myproject -d version=r99,這里的version是自己的項目版本號,在刪除之前需要查看版本號

更多文章請看本人博客

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容