有源码分享的程序员网站?各种源码软件分享

大家好,关于有源码分享的程序员网站很多朋友都还不太明白,今天小编就来为大家分享关于各种源码软件分享的知识,希望对各位有所帮助!

一个强大到超乎你的想象的异步IP池项目

async-proxy-pool

随着大型网站反扒机制的增强,更改IP登陆已经成为一种最高效的方式,为此打造一款超强IP池项目,采用最新最快的Python技术——异步(Async)。编写了一个免费的异步爬虫代理池,以Pythonasyncio为基础,充分利用Python的异步性能,异步处理比同步处理能提升成百上千倍的效率,速度堪比GO语言。

入门Python其实很容易,但是我们要去坚持学习,每一天坚持很困难,我相信很多人学了一个星期就放弃了,为什么呢?其实没有好的学习资料给你去学习,你们是很难坚持的,这是小编收集的Python入门学习资料关注,转发,私信小编“01”,即可免费领取!希望对你们有帮助

?项目介绍?

本项目通过爬虫抓取互联网上免费代理网站的IP,并且进行异步检测是否可用,如果可用就放入数据库。定时对数据库中的代理进行维护,然后通过webapi的形式供外部使用。

?项目运行环境?

项目使用了sanic,一个异步网络框架。所以建议运行Python环境为Python3.5+,并且sanic不支持Windows系统,Windows用户可以考虑使用UbuntuonWindows。

?项目总体架构?

项目主要几大模块分别是爬取模块,存储模块,校验模块,调度模块,接口模块。

爬取模块crawler.py

负责爬取代理网站,并将所得到的代理存入到数据库,每个代理的初始化权值为INIT_SCORE。

存储模块database.py

封装了Redis操作的一些接口,提供Redis连接池。

校验模块validator.py

验证代理IP是否可用,如果代理可用则权值+1,最大值为MAX_SCORE。不可用则权值-1,直至权值为0时将代理从数据库中删除。

调度模块scheduler.py

负责调度爬取器和校验器的运行。

接口模块webapi.py

使用sanic提供WEBAPI(服务器提供接口)。

?如何使用?

安装Redis

项目数据库使用了Redis,Redis是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。所以请确保运行环境已经正确安装了Redis。安装方法请参照官网指南。

项目源码

文末点击阅读原文

安装依赖

$?pip?install?-r?requirements.txt\n

?使用API获取代理?

运行代码后,访问http://127.0.0.1:5000/进入主页,如果显示&39;,证明成功启动。

访问http://127.0.0.1:5000/get可以获取一个可用代理。

也可以在程序代码中用相应的语言获取,例如:

import?requests\nfrom?bs4?import?BeautifulSoup\nimport?lxml\n\ndef?get_proxy():\n?r?=?requests.get(&39;)\n?proxy?=?BeautifulSoup(r.text,?&34;).get_text()\n?return?proxy\n

?Sanic性能测试?

使用wrk进行服务器压力测试。基准测试30秒,使用12个线程,并发400个http连接。测试http://127.0.0.1:3289/

$?wrk?-t12?-c400?-d30s?http://127.0.0.1:3289/\nRunning?30s?test?@?http://127.0.0.1:3289/\n?12?threads?and?400?connections\n?Thread?Stats?Avg?Stdev?Max?+/-?Stdev\n?Latency?34.63ms?12.66ms?96.28ms?58.07%\n?Req/Sec?0.96k?137.29?2.21k?73.29%\n?342764?requests?in?30.10s,?49.69MB?read\nRequests/sec:?11387.89\nTransfer/sec:?1.65MB\n

我们看到了什么?平均每秒钟11387.89个请求,就问你们怕不怕。机器性能更好一下,就是一波DOS攻击了。

?实际代理性能测试?

实测效果

https://taobao.com(测试淘宝

测试代理:?http://localhost:3289/get/20\n测试网站:?https://taobao.com/\n测试次数:?1000\n成功次数:?984\n失败次数:?16\n成功率:?0.984\n

https://baidu.com(测试百度

测试代理:?http://localhost:3289/get/20\n测试网站:?https://baidu.com\n测试次数:?1000\n成功次数:?975\n失败次数:?25\n成功率:?0.975\n

https://zhihu.com(测试知乎

测试代理:?http://localhost:3289/get/20\n测试网站:?https://zhihu.com\n测试次数:?1000\n成功次数:?1000\n失败次数:?0\n成功率:?1.0\n

可以看到其实性能是非常棒的,成功率极高。

?总结?

对于做爬虫的人来说,拥有一个免费的代理池是必须要。如果没有的话就需要去付费购买,有了这个项目源码之后,就相当于每个月省了至少是一百多块钱。同时Python的异步是未来的发展趋势,sanic异步框架天生就是处理百万级高并发的,如果你学会了这个项目出去找工作竞争是十分大的。

OK,本文到此结束,希望对大家有所帮助。

Published by

风君子

独自遨游何稽首 揭天掀地慰生平