DeadlineExceededError: ApplicationError: 5 при использовании функции urllib2.urlopen () - PullRequest
4 голосов
/ 23 июня 2011

В моем приложении я использую функцию urllib2.urlopen () для вызова API и получения результата от этого API. Но это не работает нормально. Иногда он показывает результат, но иногда выдает следующую ошибку:

Traceback (most recent call last):
  File "/base/python_runtime/python_lib/versions/1/google/appengine/ext/webapp/__init__.py", line 700, in __call__
handler.get(*groups)
  File "/base/data/home/apps/s~malware-app/7.351334968546050391/main.py", line 505, in get
f = urllib2.urlopen('http://whoapi.com/api-v1/?domain=%s&rtype=alexarank&apikey=xyz'% domain)
  File "/base/python_runtime/python_dist/lib/python2.5/urllib2.py", line 124, in urlopen
    return _opener.open(url, data)
  File "/base/python_runtime/python_dist/lib/python2.5/urllib2.py", line 381, in open
response = self._open(req, data)
  File "/base/python_runtime/python_dist/lib/python2.5/urllib2.py", line 399, in _open
  '_open', req)
  File "/base/python_runtime/python_dist/lib/python2.5/urllib2.py", line 360, in _call_chain
result = func(*args)
  File "/base/python_runtime/python_dist/lib/python2.5/urllib2.py", line 1114, in http_open
return self.do_open(httplib.HTTPConnection, req)
  File "/base/python_runtime/python_dist/lib/python2.5/urllib2.py", line 1087, in do_open
r = h.getresponse()
  File "/base/python_runtime/python_dist/lib/python2.5/httplib.py", line 197, in getresponse
self._allow_truncated, self._follow_redirects)
  File "/base/python_runtime/python_lib/versions/1/google/appengine/api/urlfetch.py", line 260, in fetch
return rpc.get_result()
  File "/base/python_runtime/python_lib/versions/1/google/appengine/api/apiproxy_stub_map.py", line 592, in get_result
return self.__get_result_hook(self)
  File "/base/python_runtime/python_lib/versions/1/google/appengine/api/urlfetch.py", line 364, in _get_fetch_result
raise DeadlineExceededError(str(err))
DeadlineExceededError: ApplicationError: 5 

Я видел для этого метод try-исключения, но он не работает для моего кода. Мой кодовый блок:

 try:                      
   f = urllib2.urlopen('http://whoapi.com/api-v1/?domain=%s&rtype=serverip&apikey=xyzxyz'% domain)
   ip = f.read()
 except DeadlineExceededError, e:
   self.redirect('/error')

Я импортирую:

from google.appengine.runtime import DeadlineExceededError

Из stackoverflow я узнал, что его сервер bcause не ответил в указанное время, и мы можем обработать исключение ..am, но не можем этого сделать. Любая помощь будет оценена. Спасибо за вашу помощь

Ответы [ 2 ]

12 голосов
/ 23 июня 2011

Время ожидания по умолчанию для запросов URL Fetch составляет всего 5 секунд, поэтому вы можете увеличить его, используя urlfetch напрямую:

from google.appengine.api import urlfetch

try:
    resp = urlfetch.fetch('http://whoapi.com/api-v1/?domain=%s&rtype=serverip&apikey=xyzxyz'% domain, method=urlfetch.GET, deadline=10)
    ip = r.content
except urlfetch.DownloadError:
    self.redirect('/error')

Если вы все равно постоянно обнаруживаете превышение его, рассмотрите возможность использования асинхронных запросов или перемещения логики в очередь задач.

0 голосов
/ 23 июня 2011

Как вы сказали, ошибка возникает из-за того, что вы не получили ответ вовремя, и запрос превысил крайний срок.

Что вы можете сделать, это переместить запрос в очередь задач, поскольку задачиработать намного дольше.

Что касается перехвата исключения, пытались ли вы добавить оператор возврата сразу после self.redirect?

...