python爬虫利用代理池更换IP的方法步骤

作者:y4ung 时间:2023-10-04 05:50:38 

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

python爬虫利用代理池更换IP的方法步骤

更多的用法和文档请参考:document 和 https://github.com/jhao104/proxy_pool

来源:https://blog.csdn.net/qq_35056292/article/details/109752522

标签:python,代理池,IP
0
投稿

猜你喜欢

  • sqlserver 多表关联时在where语句中慎用trim()方法

    2024-01-16 06:37:32
  • javascript实现瀑布流动态加载图片原理

    2024-06-05 09:13:54
  • SQL Server数据库和Oracle行转列的特殊方案描述

    2010-07-26 15:14:00
  • 讲解Oracle数据库中结束死锁进程的一般方法

    2024-01-17 01:16:00
  • sql server 获取系统时间的方法

    2023-07-17 07:05:36
  • selenium跳过webdriver检测并模拟登录淘宝

    2023-06-14 18:22:52
  • 浅谈django url请求与数据库连接池的共享问题

    2024-01-26 00:12:40
  • python2.7 mayavi 安装图文教程(推荐)

    2022-05-12 05:39:13
  • 对python 生成拼接xml报文的示例详解

    2021-10-24 13:07:38
  • JavaScript实现弹出DIV层同时页面背景渐变成半透明效果

    2024-04-30 10:09:27
  • SQLite数据库管理相关命令的使用介绍

    2024-01-27 12:41:00
  • 在Python的Django框架中包装视图函数

    2021-01-08 03:45:45
  • js 遍历json返回的map内容示例代码

    2024-04-16 10:32:32
  • javascript时间自动刷新实现原理与步骤

    2024-04-30 08:50:50
  • 注册和填表中常见的中英文对照

    2008-07-26 12:12:00
  • Python数据可视化图实现过程详解

    2022-08-30 19:24:17
  • asp连接mysql的问题(端口)

    2009-08-21 13:23:00
  • MySQL中数据查询语句整理大全

    2024-01-15 21:59:05
  • 离线状态下在jupyter notebook中使用plotly实例

    2022-04-19 18:05:59
  • Python实现视频裁剪的示例代码

    2022-07-20 07:14:14
  • asp之家 网络编程 m.aspxhome.com