博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python socket.error: [Errno 10054] 解决方法
阅读量:5221 次
发布时间:2019-06-14

本文共 790 字,大约阅读时间需要 2 分钟。

我用的是python2.7   我搜网上10054错误解决方法的时候发现,大部分文章都是以python3为基础的,对于python2不适用。

 

python socket.error: [Errno 10054]  远程主机强迫关闭了一个现有的连接。

原因:服务器发现你的爬虫行为了,所有强制断开链接了

解决办法:  服务器知道你是爬虫,加headers, 模拟浏览器agent;head中有一个user-agent每次都换不同的模拟代理

#coding:utf-8import urllib2url ='http://www.baidu.com'  #例子headers = {
'User-agent' : 'Mozilla/5.0 (Windows NT 6.2; WOW64; rv:22.0) Gecko/20100101 Firefox/22.0'}request = urllib2.Request(url, headers = headers)response = urllib2.urlopen(request,timeout=20)if response.getcode()==200: print response.read()

一般请求服务器爬取网页时,我都不加headers的,但是我最近再爬取之前爬取的网页时,就出现了404错误,可是发现了我的爬虫行为。加了headers之后,就又可以正常爬取了。

 

参考   
1、head中有一个user-agent每次都换不同的模拟代理
2、测试最大访问时间短,每秒多少次请求会出现中断,然后sleep(200)毫秒
3、每次请求中断上一次链接,keep-live=false
试试看,
不然就是换IP访问

转载于:https://www.cnblogs.com/yiyezhouming/p/6846139.html

你可能感兴趣的文章