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


Posted in Python onFebruary 21, 2021

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

到此这篇关于python爬虫利用代理池更换IP的方法步骤的文章就介绍到这了,更多相关python 代理池更换IP内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python中asyncore的用法实例
Sep 29 Python
Python实现更改图片尺寸大小的方法(基于Pillow包)
Sep 19 Python
利用Python操作消息队列RabbitMQ的方法教程
Jul 19 Python
在Python的一段程序中如何使用多次事件循环详解
Sep 07 Python
python使用正则表达式替换匹配成功的组并输出替换的次数
Nov 22 Python
python实现隐马尔科夫模型HMM
Mar 25 Python
[机器视觉]使用python自动识别验证码详解
May 16 Python
在Python中使用filter去除列表中值为假及空字符串的例子
Nov 18 Python
python中对二维列表中一维列表的调用方法
Jun 07 Python
基于python实现MQTT发布订阅过程原理解析
Jul 27 Python
详解pandas中利用DataFrame对象的.loc[]、.iloc[]方法抽取数据
Dec 13 Python
python 装饰器的基本使用
Jan 13 Python
Python用requests库爬取返回为空的解决办法
Feb 21 #Python
python利用proxybroker构建爬虫免费IP代理池的实现
Feb 21 #Python
python实现图片转字符画的完整代码
Feb 21 #Python
利用Python实现最小二乘法与梯度下降算法
Feb 21 #Python
Scrapy实现模拟登录的示例代码
Feb 21 #Python
scrapy-splash简单使用详解
Feb 21 #Python
详解使用scrapy进行模拟登陆三种方式
Feb 21 #Python
You might like
Zend studio文件注释模板设置方法
2013/09/29 PHP
php抽象类用法实例分析
2015/07/07 PHP
php冒泡排序与快速排序实例详解
2015/12/07 PHP
使用JQuery进行跨域请求
2010/01/25 Javascript
javascript 文件的同步加载与异步加载实现原理
2012/12/13 Javascript
javascript设计模式之解释器模式详解
2014/06/05 Javascript
超赞的动手创建JavaScript框架的详细教程
2015/06/30 Javascript
BootStrap的alert提示框的关闭后再显示怎么解决
2016/05/17 Javascript
详解自动生成博客目录案例
2016/12/09 Javascript
Node.js学习入门
2017/01/03 Javascript
jQuery Pagination分页插件使用方法详解
2017/02/28 Javascript
js中DOM三级列表(代码分享)
2017/03/20 Javascript
Vue组件全局注册实现警告框的实例详解
2018/06/11 Javascript
原生js通过一行代码实现简易轮播图
2019/06/05 Javascript
vue draggable resizable 实现可拖拽缩放的组件功能
2019/07/15 Javascript
Vue中使用better-scroll实现轮播图组件
2020/03/07 Javascript
vue抽出组件并传值实例
2020/07/31 Javascript
JS面向对象实现飞机大战
2020/08/26 Javascript
vue+高德地图实现地图搜索及点击定位操作
2020/09/09 Javascript
[01:07:46]完美世界DOTA2联赛循环赛 Magma vs IO BO2第二场 11.01
2020/11/02 DOTA
python 换位密码算法的实例详解
2017/07/19 Python
Python利用PyExecJS库执行JS函数的案例分析
2019/12/18 Python
Html5 Canvas动画基础碰撞检测的实现
2018/12/06 HTML / CSS
中海讯通笔试题
2015/09/15 面试题
设计模式的基本要素是什么
2014/04/21 面试题
大学自我鉴定范文
2013/12/26 职场文书
八年级数学教学反思
2014/01/31 职场文书
个人对照检查材料思想汇报(四风问题)
2014/09/25 职场文书
2015教师个人德育工作总结
2015/07/22 职场文书
2016年暑期见闻作文
2015/11/25 职场文书
Html分层的box-shadow效果的示例代码
2021/03/30 HTML / CSS
python 实现德洛内三角剖分的操作
2021/04/22 Python
mysql timestamp比较查询遇到的坑及解决
2021/11/27 MySQL
深入理解go缓存库freecache的使用
2022/02/15 Golang
俄罗斯十大城市人口排名,第三首都仅排第六,第二是北方首都
2022/03/20 杂记
vue打包时去掉所有的console.log
2022/04/10 Vue.js