Python搭建代理IP池实现接口设置与整体调度


Posted in Python onOctober 27, 2019

接口模块需要用 API 来提供对外服务的接口,当然也可以直接连数据库来取,但是这样就需要知道数据库的连接信息,不太安全,而且需要配置连接,所以一个比较安全和方便的方式就是提供一个 Web API 接口,通过访问接口即可拿到可用代理

代码地址:https://github.com/Stevengz/Proxy_pool

另外三篇:
Python搭建代理IP池(一)- 获取 IP
Python搭建代理IP池(二)- 存储 IP
Python搭建代理IP池(三)- 检测 IP

添加设置

添加模块开关变量

setting.py

# 数据库地址
HOST = '127.0.0.1'
# MySql端口
MYSQL_PORT = 3306
# MySQl用户名、密码
MYSQL_USERNAME = '***'
MYSQL_PASSWORD = '***'
# 数据库名
SQL_NAME = 'test'

# 代理等级
MAX_SCORE = 30
MIN_SCORE = 0
INITIAL_SCORE = 10

VALID_STATUS_CODES = [200, 302]

# 代理池数量界限
POOL_UPPER_THRESHOLD = 1000

# 检查周期
TESTER_CYCLE = 20
# 获取周期
GETTER_CYCLE = 300

# 测试API,建议抓哪个网站测哪个
TEST_URL = 'http://www.baidu.com'

# API配置
API_HOST = '0.0.0.0'
API_PORT = 5555

# 开关
TESTER_ENABLED = True
GETTER_ENABLED = True
API_ENABLED = True

# 最大批测试量
BATCH_TEST_SIZE = 10

TESTER_ENABLED、GETTER_ENABLED、API_ENABLED 都是布尔类型,True 或者 False。标明了测试模块、获取模块、接口模块的开关,如果为 True,则代表模块开启

定义接口

使用框架:Flask

api.py

from flask import Flask, g
from db import MySqlClient

__all__ = ['app']

app = Flask(__name__)

def get_conn():
 if not hasattr(g, 'mysql'):
  g.mysql = MySqlClient()
 return g.mysql

@app.route('/')
def index():
 return '<h2>Welcome to Proxy Pool System</h2>'

# 随机代理
@app.route('/random')
def get_proxy():
 conn = get_conn()
 return conn.random()

# 代理池总量
@app.route('/count')
def get_counts():
 conn = get_conn()
 return str(conn.count())

if __name__ == '__main__':
 app.run()

声明了一个 Flask 对象,定义了三个接口,分别是首页、随机代理页、获取数量页。

只需要访问对应的接口即可获取到可用代理:

Python搭建代理IP池实现接口设置与整体调度

调度模块

调用定义的获取、存储、检测三个模块,将这三个模块通过多进程的形式运行起来

scheduler.py

import time
from multiprocessing import Process
from api import app
from getter import Getter
from tester import Tester
from db import MySqlClient
from setting import *


class Scheduler():

 # 定时测试代理
 def schedule_tester(self, cycle=TESTER_CYCLE):
  tester = Tester()
  while True:
   print('测试器开始运行')
   tester.run()
   time.sleep(cycle)
 
 # 定时获取代理
 def schedule_getter(self, cycle=GETTER_CYCLE):
  getter = Getter()
  while True:
   print('开始抓取代理')
   getter.run()
   time.sleep(cycle)
 
 # 开启API
 def schedule_api(self):
  app.run(API_HOST, API_PORT)
 
 def run(self):
  print('代理池开始运行')
  
  if TESTER_ENABLED:
   tester_process = Process(target=self.schedule_tester)
   tester_process.start()
  
  if GETTER_ENABLED:
   getter_process = Process(target=self.schedule_getter)
   getter_process.start()
  
  if API_ENABLED:
   api_process = Process(target=self.schedule_api)
   api_process.start()

if __name__ == "__main__":
 scheduler = Scheduler()
 scheduler.run()

启动入口是 run() 方法,分别判断了三个模块的开关,如果开启的话,就新建一个 Process 进程,设置好启动目标,然后调用 start() 方法运行,这样三个进程就可以并行执行,互不干扰

Python搭建代理IP池实现接口设置与整体调度

Python搭建代理IP池实现接口设置与整体调度

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python学习笔记:字典的使用示例详解
Jun 13 Python
使用Python的Tornado框架实现一个一对一聊天的程序
Apr 25 Python
用python写一个windows下的定时关机脚本(推荐)
Mar 21 Python
PyTorch快速搭建神经网络及其保存提取方法详解
Apr 28 Python
Python3.6日志Logging模块简单用法示例
Jun 14 Python
python3+selenium实现qq邮箱登陆并发送邮件功能
Jan 23 Python
django-filter和普通查询的例子
Aug 12 Python
使用opencv中匹配点对的坐标提取方式
Jun 04 Python
互斥锁解决 Python 中多线程共享全局变量的问题(推荐)
Sep 28 Python
详解Java中一维、二维数组在内存中的结构
Feb 11 Python
TensorFlow的环境配置与安装方法
Feb 20 Python
Python爬取用户观影数据并分析用户与电影之间的隐藏信息!
Jun 29 Python
Python搭建代理IP池实现检测IP的方法
Oct 27 #Python
浅析使用Python搭建http服务器
Oct 27 #Python
Python搭建代理IP池实现存储IP的方法
Oct 27 #Python
Python搭建代理IP池实现获取IP的方法
Oct 27 #Python
详解python statistics模块及函数用法
Oct 27 #Python
在 Jupyter 中重新导入特定的 Python 文件(场景分析)
Oct 27 #Python
python自动结束mysql慢查询会话的实例代码
Oct 27 #Python
You might like
浅析php学习的路线图
2013/07/10 PHP
PHP使用Mysqli类库实现完美分页效果的方法
2016/04/07 PHP
PHP 将dataurl转成图片image方法总结
2016/10/14 PHP
javascript-TreeView父子联动效果保持节点状态一致
2007/08/12 Javascript
javascript this用法小结
2008/12/19 Javascript
javascript 浏览器判断 绑定事件 arguments 转换数组 数组遍历
2009/07/06 Javascript
javascript高级程序设计第二版第十二章事件要点总结(常用的跨浏览器检测方法)
2012/08/22 Javascript
关于锚点跳转及jQuery下相关操作与插件
2012/10/01 Javascript
给页面渲染时间加速 干掉Dom Level 0 Event
2012/12/19 Javascript
js实现鼠标滚轮控制图片缩放效果的方法
2015/02/20 Javascript
浅谈javascript属性onresize
2015/04/20 Javascript
ES6新特性:使用export和import实现模块化详解
2017/07/31 Javascript
浅谈NodeJs之数据库异常处理
2017/10/25 NodeJs
学习JS中的DOM节点以及操作
2018/04/30 Javascript
Mint-UI时间组件起始时间问题及时间插件使用
2018/08/20 Javascript
微信小程序设置全局请求URL及封装wx.request请求操作示例
2019/04/02 Javascript
详解webpack打包vue项目之后生成的dist文件该怎么启动运行
2019/09/06 Javascript
VUE+elementui组件在table-cell单元格中绘制微型echarts图
2020/04/20 Javascript
Vue 防止短时间内连续点击后多次触发请求的操作
2020/11/11 Javascript
element el-table表格的二次封装实现(附表格高度自适应)
2021/01/19 Javascript
详解用python实现简单的遗传算法
2018/01/02 Python
Python用61行代码实现图片像素化的示例代码
2018/12/10 Python
python画图系列之个性化显示x轴区段文字的实例
2018/12/13 Python
python实现Dijkstra静态寻路算法
2019/01/17 Python
pygame实现俄罗斯方块游戏(基础篇1)
2019/10/29 Python
H5页面适配iPhoneX(就是那么简单)
2019/12/02 HTML / CSS
托管代码(Managed Code)和非托管代码(Unmanaged Code)有什么区别
2014/09/29 面试题
医学院四年学习生活的自我评价
2013/11/06 职场文书
酒店副总经理岗位职责范本
2014/02/04 职场文书
2014年端午节活动方案
2014/03/11 职场文书
群众路线党员个人剖析材料
2014/10/08 职场文书
办公室文员岗位职责
2015/02/04 职场文书
假如给我三天光明读书笔记
2015/06/26 职场文书
2016年春季运动会通讯稿
2015/11/25 职场文书
2016大一新生入学教育心得体会
2016/01/23 职场文书
PostgreSQL聚合函数介绍以及分组和排序
2022/04/12 PostgreSQL