Aus was ich von tornado.gen Modul Dokumentation verstehe ist, dass tornado.gen.Task umfasst tornado.gen.Callback und tornado.gen.Wait mit jedem Callback/Wait-Paar mit eindeutigen Schlüsseln zugeordnet. ..Tornado Async HTTP Ergebnisse inkrementell zurückgeben
@tornado.web.asynchronous
@tornado.gen.engine
def get(self):
http_client = AsyncHTTPClient()
http_client.fetch("http://google.com",
callback=(yield tornado.gen.Callback("google")))
http_client.fetch("http://python.org",
callback=(yield tornado.gen.Callback("python")))
http_client.fetch("http://tornadoweb.org",
callback=(yield tornado.gen.Callback("tornado")))
response = yield [tornado.gen.Wait("google"), tornado.gen.Wait("tornado"), tornado.gen.Wait("python")]
do_something_with_response(response)
self.render("template.html")
Also der obige Code wird alle Antworten von den verschiedenen URLs erhalten. Jetzt muss ich eigentlich die Antwort zurückgeben, sobald ein http_client die Daten zurückgibt. Wenn also 'tornadoweb.org' die Daten zuerst zurückgibt, sollte es ein self.write (respose) machen und eine Schleife in def get() sollte warten, bis andere http_clients fertig sind. Irgendwelche Ideen, wie man dies mit tornado.gen Interface schreibt.
Sehr vage Umsetzung (und syntaktisch falsch) von dem, was ich versuche wie diese
class GenAsyncHandler2(tornado.web.RequestHandler):
@tornado.web.asynchronous
@tornado.gen.engine
def get(self):
http_client = AsyncHTTPClient()
http_client.fetch("http://google.com",
callback=(yield tornado.gen.Callback("google")))
http_client.fetch("http://python.org",
callback=(yield tornado.gen.Callback("python")))
http_client.fetch("http://tornadoweb.org",
callback=(yield tornado.gen.Callback("tornado")))
while True:
response = self.get_response()
if response:
self.write(response)
self.flush()
else:
break
self.finish()
def get_response(self):
for key in tornado.gen.availableKeys():
if key.is_ready:
value = tornado.gen.pop(key)
return value
return None