[英]Google App Engine Task Queue Error using Python API
我已經為正在玩的Flask + GAE項目實現了一個任務隊列操作,以了解有關Python Web開發的更多信息,並且遇到了以下錯誤,並且無法跟蹤有關它的任何信息。
----------------------------------------
Exception happened during processing of request from ('0.1.0.2', 80)
Traceback (most recent call last):
File "/usr/local/Cellar/python/2.7.1/lib/python2.7/SocketServer.py", line 284, in _handle_request_noblock
self.process_request(request, client_address)
File "/usr/local/Cellar/python/2.7.1/lib/python2.7/SocketServer.py", line 311, in process_request
self.shutdown_request(request)
File "/usr/local/Cellar/python/2.7.1/lib/python2.7/SocketServer.py", line 459, in shutdown_request
request.shutdown(socket.SHUT_WR)
AttributeError: 'FakeConnection' object has no attribute 'shutdown'
----------------------------------------
我有一個視圖正在接受我的應用程序中另一個視圖的POST請求,據我所知,它正在執行我期望的所有處理,除了它將結束並吐出。 我猜這是因為我在GAE devserver日志中看到以下輸出:
INFO 2011-01-23 21:41:16,865 dev_appserver.py:3317] "GET /main/new HTTP/1.1" 200 -
INFO 2011-01-23 21:41:23,753 dev_appserver.py:3317] "POST /main/new HTTP/1.1" 302 -
INFO 2011-01-23 21:41:24,528 dev_appserver.py:3317] "POST /tasks/check_for_spam HTTP/1.1" 200 -
check_for_spam東西是一個通過Defensio API運行某些數據以確定是否為垃圾郵件的函數。 這是代碼
from google.appengine.api import taskqueue
from google.appengine.ext import db
from google.appengine.ext import webapp
from google.appengine.ext.webapp.util import run_wsgi_app
from application.models import LieModel
from defensio import *
class SpamChecker(webapp.RequestHandler):
def post(self):
id = self.request.get('id')
client = Defensio('577709b41d42f2c34f80cd57d50333d6')
q = LieModel.all()
q.filter("id = ", id)
results = q.fetch(1)
for result in results:
title_doc = {'content': result.title, 'type': 'comment', 'platform':'python'}
body_doc = {'content': result.body, 'type': 'comment', 'platform':'python'}
title_status,title_response = client.post_document(title_doc)
body_status,body_response = client.post_document(body_doc)
lie_is_spam = False
if title_status == 200 and title_response['defensio-result']['spaminess'] > 0.5:
lie_is_spam = True
if body_status == 200 and body_response['defensio-result']['spaminess'] > 0.5:
lie_is_spam = True
if lie_is_spam:
lie_k = db.Key.from_path('Lie', id)
lie = db.get(lie_k)
lie.delete()
def main():
run_wsgi_app(webapp.WSGIApplication([
('/tasks/check_for_spam', SpamChecker)
]))
if __name__ == '__main__':
main()
解決此問題的任何幫助將不勝感激。
羅伯特·克魯因的建議使問題消失了。 我正在通過使用啟動開發服務器
python2.5 /usr/local/bin/dev_appserver.py .
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.