Dwi*_*ing 9 python twitter ssl tweepy
我有一个Django管理命令,通过supervisord启动,使用tweepy来使用twitter流API.
代理工作得很好但是我注意到日志中每隔10-15分钟就有一个SSLError,并且supervisord正在重新启动代理.
tweepy包是最新版本1.11.服务器是ubuntu 12.04 LTS.我已经尝试将cacert安装到钥匙链中,如下面的链接所示,但没有运气.
有什么建议?
[2012-08-26 19:28:15,656: ERROR] Error establishing the connection
Traceback (most recent call last):.../.../datasinks.py", line 102, in start
stream.filter(locations=self.locations)
File "/site/pythonenv/local/lib/python2.7/site-packages/tweepy/streaming.py", line 228, in filter
self._start(async)
File "/site/pythonenv/local/lib/python2.7/site-packages/tweepy/streaming.py", line 172, in _start
self._run()
File "/site/pythonenv/local/lib/python2.7/site-packages/tweepy/streaming.py", line 117, in _run
self._read_loop(resp)
File "/site/pythonenv/local/lib/python2.7/site-packages/tweepy/streaming.py", line 150, in _read_loop
c = resp.read(1)
File "/usr/lib/python2.7/httplib.py", line 541, in read
return self._read_chunked(amt)
File "/usr/lib/python2.7/httplib.py", line 574, in _read_chunked
line = self.fp.readline(_MAXLINE + 1)
File "/usr/lib/python2.7/socket.py", line 476, in readline
data = self._sock.recv(self._rbufsize)
File "/usr/lib/python2.7/ssl.py", line 241, in recv
return self.read(buflen)
File "/usr/lib/python2.7/ssl.py", line 160, in read
return self._sslobj.read(len)
SSLError: The read operation timed out
Run Code Online (Sandbox Code Playgroud)
以下是代码的概述.
from tweepy import API, OAuthHandler
from tweepy.streaming import StreamListener, Stream
# snip other imports
class TwitterSink(StreamListener, TweetSink):
def __init__(self):
self.auth = OAuthHandler(settings.TWITTER_OAUTH_CONSUMER_KEY, settings.TWITTER_OAUTH_CONSUMER_SECRET)
self.auth.set_access_token(settings.TWITTER_OAUTH_ACCESS_TOKEN_KEY, settings.TWITTER_OAUTH_ACCESS_TOKEN_SECRET)
self.locations = '' # Snip for brevity
def start(self):
try:
stream = Stream(self.auth, self,timeout=60, secure=True)
stream.filter(locations=self.locations)
except SSLError as e:
logger.exception("Error establishing the connection")
except IncompleteRead as r:
logger.exception("Error with HTTP connection")
# snip on_data()
# snip on_timeout()
# snip on_error()
Run Code Online (Sandbox Code Playgroud)
证书似乎不是问题.错误只是暂停.似乎是对我的twepy SSL处理问题.代码可以处理socket.timeout和重新打开连接,但不会通过超时SSLError.
但是,看一下ssl模块代码(或文档),我没有看到很好的方法来捕获它.在SSLError没有任何参数的情况下引发对象,只是字符串描述.由于缺乏更好的解决方案,我建议在tweepy/streaming.py第118行之前添加以下内容:
except SSLError, e:
if 'timeout' not in exception.message.lower(): # support all timeouts
exception = e
break
if self.listener.on_timeout() == False:
break
if self.running is False:
break
conn.close()
sleep(self.snooze_time)
Run Code Online (Sandbox Code Playgroud)
为什么它首先超时是一个很好的问题.我没有什么比重复Travis Mehlinger的建议更高的建议更好了timeout.
| 归档时间: |
|
| 查看次数: |
7185 次 |
| 最近记录: |