爬蟲ip代理池搭建前需解決的問題及搭建思路

太陽小諸葛發表於2018-12-20

在公司做分散式深網爬蟲,搭建了一套穩定的代理池服務,為上千個爬蟲提供有效的代理,保證各個爬蟲拿到的都是對應網站有效的代理IP,從而保證爬蟲快速穩定的執行,當然在公司做的東西不能開源出來。不過呢,閒暇時間手癢,所以就想利用一些免費的資源搞一個簡單的代理池服務。


1、問題


代理IP從何而來?


剛自學爬蟲的時候沒有代理IP就去西刺、快代理之類有免費代理的網站去爬,還是有個別代理能用。當然,如果你有更好的代理介面也可以自己接入。

免費代理的採集也很簡單,無非就是:訪問頁面頁面 —> 正則/xpath提取 —> 儲存


如何保證代理質量?


可以肯定免費的代理IP大部分都是不能用的,不然別人為什麼還提供付費的(不過事實是很多代理商的付費IP也不穩定,也有很多是不能用)。所以採集回來的代理IP不能直接使用,可以寫檢測程式不斷的去用這些代理訪問一個穩定的網站,看是否可以正常使用。這個過程可以使用多執行緒或非同步的方式,因為檢測代理是個很慢的過程。


採集回來的代理如何儲存?


這裡不得不推薦一個高效能支援多種資料結構的NoSQL資料庫SSDB,用於代理Redis。支援佇列、hash、set、k-v對,支援T級別資料。是做分散式爬蟲很好中間儲存工具。


如何讓爬蟲更簡單的使用這些代理?


答案肯定是做成服務咯,python有這麼多的web框架,隨便拿一個來寫個api供爬蟲呼叫。這樣有很多好處,比如:當爬蟲發現代理不能使用可以主動透過api去delete代理IP,當爬蟲發現代理池IP不夠用時可以主動去refresh代理池。這樣比檢測程式更加靠譜。 


2、代理池設計


代理池由四部分組成:


ProxyGetter:


代理獲取介面,目前有5個免費代理源,每呼叫一次就會抓取這個5個網站的最新代理放入DB,可自行新增額外的代理獲取介面;


DB:


用於存放代理IP,現在暫時只支援SSDB。至於為什麼選擇SSDB,大家可以參考這篇文章,個人覺得SSDB是個不錯的Redis替代方案,如果你沒有用過SSDB,安裝起來也很簡單,可以參考這裡;


Schedule:


計劃任務使用者定時去檢測DB中的代理可用性,刪除不可用的代理。同時也會主動透過ProxyGetter去獲取最新代理放入DB;


ProxyApi:


代理池的外部介面,由於現在這麼代理池功能比較簡單,花兩個小時看了下Flask,愉快的決定用Flask搞定。功能是給爬蟲提供get/delete/refresh等介面,方便爬蟲直接使用。


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31561288/viewspace-2285933/,如需轉載,請註明出處,否則將追究法律責任。

相關文章