Очереди задач Google App Engine - неприятный сбой - PullRequest
4 голосов
/ 06 февраля 2011

Я разрабатываю приложение для GAE и пытаюсь использовать очереди задач. В настоящее время я просто запускаю приложение на своем Windows-устройстве через GAE App Launcher, но всякий раз, когда я пытаюсь что-то поставить в очередь, «сервер» разработки вылетает, и журнал полон неприятных результатов.

taskqueue.add(url='/processWork', params={'key', myModel.key()})

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

Однако вскоре после этого происходит сбой сервера разработки, и журнал полон таких вещей:

ERROR    2011-02-06 17:04:23,289
__init__.py:395] global name 'true' is not defined Traceback (most recent call last):   File "C:\Program Files (x86)\Google\google_appengine\google\appengine\ext\webapp\__init__.py", line 517, in __call__
    handler.post(*groups)   File "C:\Projects\GAE\MyApp\main.py", line 114, in post
    activity.approved = true NameError: global name 'true' is not defined INFO     2011-02-06 17:04:23,309 dev_appserver.py:3317] "POST /processWork HTTP/1.1" 500 - WARNING  2011-02-06 17:04:23,309 taskqueue_stub.py:586] Task named "task1" on queue "default" failed with code 500; will retry in 30 seconds Traceback (most recent call last):   File "C:\Python27\lib\SocketServer.py", line 284, in _handle_request_noblock
    self.process_request(request, client_address)   File "C:\Python27\lib\SocketServer.py", line 311, in process_request
    self.shutdown_request(request)   File "C:\Python27\lib\SocketServer.py", line 459, in shutdown_request
    request.shutdown(socket.SHUT_WR) AttributeError: 'FakeConnection' object has no attribute 'shutdown' ERROR    2011-02-06 17:04:23,312 dev_appserver_main.py:494] Error encountered: Traceback (most recent call last):
    File "C:\Program Files (x86)\Google\google_appengine\google\appengine\tools\dev_appserver_main.py", line 488, in main
    http_server.serve_forever()
    File "C:\Program Files (x86)\Google\google_appengine\google\appengine\tools\dev_appserver.py", line 3947, in serve_forever
    self.handle_request()
    File "C:\Program Files (x86)\Google\google_appengine\google\appengine\tools\dev_appserver.py", line 3913, in handle_request
    self._handle_request_noblock()
    File "C:\Python27\lib\SocketServer.py", line 287, in _handle_request_noblock
    self.shutdown_request(request)
    File "C:\Python27\lib\SocketServer.py", line 459, in shutdown_request
    request.shutdown(socket.SHUT_WR)   AttributeError: 'FakeConnection' object has no attribute 'shutdown'   Now terminating.
---------------------------------------- Exception happened during processing of request from ('0.1.0.2', 80)
---------------------------------------- 2011-02-06 09:04:23 (Process exited with code 1)

Извинения - ответ ниже обнаружил опечатку (правда, не правда). Тем не менее, это закралось при попытке решить исходную проблему, хотя. Если я исправлю опечатку, работа в очереди будет завершена, но мой сервер все еще падает с этой ошибкой в ​​журнале:

INFO     2011-02-06 17:50:32,882 dev_appserver.py:3317] "POST /processWork HTTP/1.1" 200 -
Traceback (most recent call last):
  File "C:\Python27\lib\SocketServer.py", line 284, in _handle_request_noblock
    self.process_request(request, client_address)
  File "C:\Python27\lib\SocketServer.py", line 311, in process_request
    self.shutdown_request(request)
  File "C:\Python27\lib\SocketServer.py", line 459, in shutdown_request
    request.shutdown(socket.SHUT_WR)
AttributeError: 'FakeConnection' object has no attribute 'shutdown'
ERROR    2011-02-06 17:50:32,884 dev_appserver_main.py:494] Error encountered:
Traceback (most recent call last):

  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\tools\dev_appserver_main.py", line 488, in main
    http_server.serve_forever()

  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\tools\dev_appserver.py", line 3947, in serve_forever
    self.handle_request()

  File "C:\Program Files (x86)\Google\google_appengine\google\appengine\tools\dev_appserver.py", line 3913, in handle_request
    self._handle_request_noblock()

  File "C:\Python27\lib\SocketServer.py", line 287, in _handle_request_noblock
    self.shutdown_request(request)

  File "C:\Python27\lib\SocketServer.py", line 459, in shutdown_request
    request.shutdown(socket.SHUT_WR)

AttributeError: 'FakeConnection' object has no attribute 'shutdown'

Now terminating.
----------------------------------------
Exception happened during processing of request from ('0.1.0.2', 80)
----------------------------------------
2011-02-06 09:50:32 (Process exited with code 1)

Если я удалю вызов taskqueue.add, он будет работать нормально (без работы в очереди, конечно). Что не так?

Ответы [ 5 ]

8 голосов
/ 06 февраля 2011
File "C:\Python27\lib\SocketServer.py"

App Engine работает с Python 2.5, и вы используете Python 2.7.

5 голосов
/ 06 февраля 2011

Выглядит как простая опечатка:

__init__.py:395] global name 'true' is not defined 
Traceback (most recent call last):   
File "C:\Program Files (x86)\Google\google_appengine\google\appengine\ext\webapp\__init__.py", line 517, in __call__
    handler.post(*groups)   
File "C:\Projects\GAE\MyApp\main.py", line 114, in post
    activity.approved = true NameError: global name 'true' is not defined

Перейдите на main.py строку 395 и измените

 activity.approved = true

на

 activity.approved = True

(заглавными буквами) T«)

0 голосов
/ 06 мая 2013

Другая возможная причина в том, что вы не можете импортировать midule

from google.appengine.api import taskqueue
0 голосов
/ 23 мая 2011

На самом деле для этого можно исправить патч обезьяны (требуется для Python 2.7.1, pyOpenSSL 0.12 и Werkzeug 0.6.2): ​​

### WARNING: Monkey patch in a fix to correct pyOpenSSL's
### incompatible ServerSocket implementation that accepts zero arguments
### for shutdown() instead of one. Fix is for:
### lib/python2.7/SocketServer.py:459's shutdown() call because that
### appears to be easier to quickly hack in versus patching
### pyOpenSSL. Again, don't use this for production, but it's great for
### testing.
def monkeyp_ssl_shutdown_request(self, request):
    try:
        request.shutdown()
    except socket.error:
        pass #some platforms may raise ENOTCONN here
    self.close_request(request)
from SocketServer import TCPServer
TCPServer.shutdown_request = monkeyp_ssl_shutdown_request

Не красиво, но лучше, чем исключение, когда кто-то закрывает TCP-соединение SSL.

app.run(ssl_context='adhoc') # Now works
0 голосов
/ 06 февраля 2011

Да, это потому, что вы используете 2.7.shutdown() было добавлено в 2,6 .Вы должны запустить 2.5 .

...