Da quello che ho capito dai documenti del modulo tornado.gen è che il file tornado.gen.Task comprende tornado.gen.Callback e tornado.gen.Wait con ogni coppia di richiamata/attesa associata a chiavi univoche. ..Tornado Async HTTP restituisce i risultati in modo incrementale
@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")
Così il codice sopra otterrà tutte le risposte dai diversi URL. Ora quello che devo effettivamente realizzare è restituire la risposta non appena un http_client restituisce i dati. Quindi se 'tornadoweb.org' restituisce i dati per primi, dovrebbe eseguire un self.write (respose) e un loop in def get() dovrebbe continuare ad attendere il completamento di altri http_clients. Qualche idea su come scrivere questo usando l'interfaccia di tornado.gen.
Molto vaga implementazione (e sintatticamente corretto) di quello che sto cercando di fare sarebbe come questo
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