tornado.genモジュールのドキュメントから私が理解していることから、 tornado.gen.Task は tornado.gen.Callback と tornado.gen.Wait で構成され、各 Callback/Wait ペアは一意のキーに関連付けられています...
@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")
したがって、上記のコードは、さまざまな URL からすべての応答を取得します。ここで実際に達成する必要があるのは、1 つの http_client がデータを返したらすぐに応答を返すことです。したがって、「tornadoweb.org」が最初にデータを返す場合、self.write(respose) を実行し、def get() のループは他の http_clients が完了するまで待機し続ける必要があります。tornado.gen インターフェイスを使用してこれを記述する方法に関するアイデア。
私がやろうとしていることの非常にあいまいな実装(および構文的に正しくない)は、次のようになります
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