项目需要,采集过各类地图数据,还有一些大型网站数据。
工具/原料
1
电脑/网络
2
618IP
3
爬虫
经验如下:
IP必须需要多,比如ADSL。如果有条件,其实可以跟机房多申请外网IP。在有外网IP的机器上,部署代理服务器。你的程序,使用轮训替换代理服务器来访问想要采集的网站。
好处:
程序逻辑变化小,只需要代理功能。根据对方网站屏蔽规则不同,你只需要添加更多的代理就行了。就算具体IP被屏蔽了,你可以直接把代理服务器下线就OK,程序逻辑不需要变化。
方法/步骤1
1
有小部分网站的防范措施比较弱,可以伪装下IP,修改X-Forwarded-for(貌似这么拼。。。)即可绕过。大部分网站么,如果要频繁抓取,一般还是要多IP。我比较喜欢的解决方案是国外VPS再配多IP,通过默认网关切换来实现IP切换,比HTTP代理高效得多,估计也比多数情况下的ADSL切换更高效。
2
· ADSL + 脚本,监测是否被封,然后不断切换 ip· 设置查询频率限制正统的做法是调用该网站提供的服务接口。
3
8年多爬虫经验的人告诉你,国内ADSL是王道,多申请些线路,分布在多个不同的电信区局,能跨省跨市更好,自己写好断线重拨组件,自己写动态IP追踪服务,远程硬件重置(主要针对ADSL猫,防止其宕机),其余的任务分配,数据回收,都不是大问题。我的已经稳定运行了好几年了,妥妥的!
4
网站封的依据一般是单位时间内特定IP的访问次数.我是将采集的任务按 目标站点的IP进行分组 通过控制每个IP 在单位时间内发出任务的个数,来避免被封.当然,这个前题是你采集很多网站.如果只是采集一个网站,那么只能通过多外部IP的方式来实现了.
注意事项
1
不过做违反道德规范之事
2
小编使用的618IP代理
上一篇:steam吃鸡被误封怎么办
下一篇:如何解决qq被封号的问题