2013-12-14 38 views
5

下面的代碼:的Python:請求模塊拋出異常與GEVENT

import gevent 
import gevent.monkey 
gevent.monkey.patch_socket() 

import requests 
import json 

base_url = 'https://api.getclever.com' 
section_url = base_url + '/v1.1/sections' 

#get all sections 
sections = requests.get(section_url, auth=('DEMO_KEY', '')).json() 
urls = [base_url+data['uri']+'/students' for data in sections['data']] 

#get students for each section 
threads = [gevent.spawn(requests.get, url, auth=('DEMO_KEY', '')) for url in urls] 
gevent.joinall(threads) 
students = [thread.value for thread in threads] 

#get number of students in each section 
num_students = [len(student.json()['data']) for student in students] 
print (sum(num_students)/len(num_students)) 

導致此錯誤:

Traceback (most recent call last): 
    File "clever.py", line 12, in <module> 
    sections = requests.get(section_url, auth=('DEMO_KEY', '')).json() 
    File "/Library/Python/2.7/site-packages/requests/api.py", line 55, in get 
    return request('get', url, **kwargs) 
    File "/Library/Python/2.7/site-packages/requests/api.py", line 44, in request 
    return session.request(method=method, url=url, **kwargs) 
    File "/Library/Python/2.7/site-packages/requests/sessions.py", line 382, in request 
    resp = self.send(prep, **send_kwargs) 
    File "/Library/Python/2.7/site-packages/requests/sessions.py", line 485, in send 
    r = adapter.send(request, **kwargs) 
    File "/Library/Python/2.7/site-packages/requests/adapters.py", line 379, in send 
    raise SSLError(e) 
requests.exceptions.SSLError: [Errno 2] _ssl.c:503: The operation did not complete (read) 

我在做什麼錯在這裏?

回答

7

以下是一個類似的問題:[Errno 2] _ssl.c:504: The operation did not complete (read)

當你註釋掉

gevent.monkey.patch_socket() 

或使用

gevent.monkey.patch_all() 

或使用

​​

然後問題消失。

+0

謝謝! patch_all()修復了它。 – tldr

+0

我認爲這個答案不再適用於'patch_ssl'函數[已被刪除](https://github.com/mopemope/meinheld/commit/68e5854bbc43e0010b56c80248e15a97336dfe6d) – EoghanM

+0

@EoghanM根本沒有。它**完美**適用於我。 –