校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > python爬蟲利用代理池更換IP的方法步驟

python爬蟲利用代理池更換IP的方法步驟

熱門標簽:柳州正規電銷機器人收費 高德地圖標注字母 申請辦個400電話號碼 鎮江人工外呼系統供應商 騰訊地圖標注有什么版本 400電話辦理費用收費 千呼ai電話機器人免費 深圳網絡外呼系統代理商 外呼系統前面有錄音播放嗎

0. 前言

周日在爬一個國外網站的時候,發現用協程并發請求,并且請求次數太快的時候,會出現對方把我的服務器IP封掉的情況。于是網上找了一下開源的python代理池,這里選擇的是star數比較多的proxy_pool

1. 安裝環境

# 安裝python虛擬環境, python環境最好為python3.6,再往上的話,安裝依賴時會報錯
sudo apt update
sudo apt install python3.6
pip3 install virtualenv
virtualenv venv --python=python3.6
source venv/bin/activate

# 安裝redis
sudo apt install redis-server
# 啟動redis server
redis-server

 2. 安裝依賴

git clone https://github.com/jhao104/proxy_pool.git
cd proxy_pool
pip install -r requirements.txt

3. 修改配置文件

# 修改setting.py 

# 配置API服務

HOST = "0.0.0.0"    # IP
PORT = 5010     # 監聽端口

# 配置數據庫

# 以下為三個示例,根據redis的配置,選擇其中一種即可
# 一般啟動redis時如果沒有配置文件,那么選擇第一種即可
# 1. Redis IP: 127.0.0.1 Port: 6379
DB_CONN = 'redis://@127.0.0.1:6379'
# 2. Redis IP: 127.0.0.1 Port: 6379 Password: 123456
DB_CONN = 'redis://:123456@127.0.0.1:6379'
# 3. Redis IP: 127.0.0.1 Port: 6379 Password: 123456 DB: 15
DB_CONN = 'redis://:123456@127.0.0.1:6379/15'

 

# 配置 ProxyFetcher

PROXY_FETCHER = [
 "freeProxy01",  # 這里是啟用的代理抓取方法名,所有fetch方法位于fetcher/proxyFetcher.py
 "freeProxy02",
 # ....
]

4. 啟動

# 可以用tmux開三個窗口

# 啟動調度程序
python proxyPool.py schedule

# 啟動webApi服務
python proxyPool.py server

5. 測試

import requests

def get_proxy():
 return requests.get("http://127.0.0.1:5010/get/").json()

def delete_proxy(proxy):
 requests.get("http://127.0.0.1:5010/delete/?proxy={}".format(proxy))

# your spider code

def getHtml():
 # ....
 retry_count = 5
 proxy = get_proxy().get("proxy")
 while retry_count > 0:
  try:
   html = requests.get('http://www.example.com', proxies={"http": "http://{}".format(proxy)})
   # 使用代理訪問
   return html
  except Exception:
   retry_count -= 1
 # 刪除代理池中代理
 delete_proxy(proxy)
 return None

更多的用法和文檔請參考:document 和 https://github.com/jhao104/proxy_pool

到此這篇關于python爬蟲利用代理池更換IP的方法步驟的文章就介紹到這了,更多相關python 代理池更換IP內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python利用proxybroker構建爬蟲免費IP代理池的實現
  • python如何基于redis實現ip代理池
  • python實現ip代理池功能示例
  • python3 requests中使用ip代理池隨機生成ip的實例

標簽:哈爾濱 郴州 大慶 合肥 平頂山 海南 烏蘭察布 烏蘭察布

巨人網絡通訊聲明:本文標題《python爬蟲利用代理池更換IP的方法步驟》,本文關鍵詞  python,爬蟲,利用,代理,池,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python爬蟲利用代理池更換IP的方法步驟》相關的同類信息!
  • 本頁收集關于python爬蟲利用代理池更換IP的方法步驟的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 平乡县| 汤阴县| 克什克腾旗| 宾川县| 中山市| 新蔡县| 灌云县| 黄龙县| 满城县| 株洲县| 卫辉市| 长沙市| 宁阳县| 武汉市| 确山县| 东乌| 定结县| 河东区| 容城县| 绍兴县| 星子县| 久治县| 广宗县| 莱阳市| 遵义县| 洛南县| 乌拉特中旗| 逊克县| 北海市| 凤山县| 丹寨县| 枞阳县| 运城市| 手游| 庆阳市| 石城县| 子洲县| 永仁县| 佳木斯市| 固阳县| 湟中县|