我使用Redis的與我同ASYC客戶Brukva龍捲風應用程序一起,當我看着在Brukva網站上的示例應用程序,他們正在製造的WebSocket的「初始化」的方法新的連接在Tornado中處理Redis連接的正確方法是什麼? (異步 - 發佈/訂閱)
class MessagesCatcher(tornado.websocket.WebSocketHandler):
def __init__(self, *args, **kwargs):
super(MessagesCatcher, self).__init__(*args, **kwargs)
self.client = brukva.Client()
self.client.connect()
self.client.subscribe('test_channel')
def open(self):
self.client.listen(self.on_message)
def on_message(self, result):
self.write_message(str(result.body))
def close(self):
self.client.unsubscribe('test_channel')
self.client.disconnect()
它在websocket的情況下很好,但如何處理它在普通的Tornado RequestHandler post方法中說長查詢操作(發佈 - 訂閱模型)。我正在更新處理程序的每個後期方法中的新客戶端連接是這種正確的方法?當我在Redis控制檯進行檢查時,發現客戶在每次新的操作後都會增加。
這裏是我的代碼示例。
c = brukva.Client(host = '127.0.0.1')
c.connect()
class MessageNewHandler(BaseHandler):
@tornado.web.authenticated
def post(self):
self.listing_id = self.get_argument("listing_id")
message = {
"id": str(uuid.uuid4()),
"from": str(self.get_secure_cookie("username")),
"body": str(self.get_argument("body")),
}
message["html"] = self.render_string("message.html", message=message)
if self.get_argument("next", None):
self.redirect(self.get_argument("next"))
else:
c.publish(self.listing_id, message)
logging.info("Writing message : " + json.dumps(message))
self.write(json.dumps(message))
class MessageUpdatesHandler(BaseHandler):
@tornado.web.authenticated
@tornado.web.asynchronous
def post(self):
self.listing_id = self.get_argument("listing_id", None)
self.client = brukva.Client()
self.client.connect()
self.client.subscribe(self.listing_id)
self.client.listen(self.on_new_messages)
def on_new_messages(self, messages):
# Closed client connection
if self.request.connection.stream.closed():
return
logging.info("Getting update : " + json.dumps(messages.body))
self.finish(json.dumps(messages.body))
self.client.unsubscribe(self.listing_id)
def on_connection_close(self):
# unsubscribe user from channel
self.client.unsubscribe(self.listing_id)
self.client.disconnect()
我很感激你是否提供了一些類似案例的示例代碼。
Python中使用Redis,ZMQ和Tornado的異步PubSub - https://github.com/abhinavsingh/async_pubsub –