Por lo que entiendo de los documentos del módulo tornado.gen es que tornado.gen.Task compone de tornado.gen.Callback y tornado.gen.Wait con cada par de devolución de llamada/espera asociada con claves únicas. ..Tornado asincrónicos HTTP devolver resultados incrementalmente
@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")
Así que el código anterior obtendrá todas las respuestas de las diferentes URL. Ahora lo que realmente tengo que lograr es devolver la respuesta tan pronto como uno http_client devuelve los datos. Así que si 'tornadoweb.org' devuelve los datos en primer lugar, se debe hacer un self.write (respose) y un bucle en def get() debe seguir esperando otros http_clients para completar. Cualquier ideas sobre cómo escribir utilizando esta interfaz tornado.gen.
aplicación muy vaga (y sintácticamente incorrecta) de lo que estoy tratando de hacer esto sería como
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