我正在开发一个在后端使用Tornado的聊天应用程序。我使用长轮询来获取在线用户的数量以及服务器上可用的任何新聊天消息。我已经与服务器打开了两个长轮询连接。
虽然很容易检测到用户何时上线。
我编写了这个类,它维护了一个在线用户的列表(用户)。
此列表很容易发送到任何请求在线用户的客户端(如下面的代码所示)。
但是当用户下线时,我无法知道这一点,因此列表(用户)窗台保持不变。因此,即使有人离线,我也无法更新用户列表。
请帮我找出一种方法,可以删除未连接的用户(使用长轮询)并更新用户列表。
我听说我必须在列表用户上应用某种轮询机制,因为在龙卷风中不会生成断开连接事件,这与node.js不同。
请帮我实现该轮询机制。代码中的响应将受到高度赞赏。
class OnlineHandler(BaseHandler):
online = []
identifier = []
user = []
time = []
@tornado.web.asynchronous
def post(self):
random = self.get_argument("random", None)
self.online_user(self.get_current_user(), self.retuser,random)
def online_user(self, u, callback, random):
cls = OnlineHandler
if u not in cls.user:
cls.time.append(time.time())
cls.user.append(u)
else:
index = cls.user.index(u)
cls.time[index] = time.time()
cls.online.append(callback)
if random not in cls.identifier: # new user connected
cls.identifier.append(random)
logging.info("Sending online list to %r users",len(cls.online))
for callback in cls.online:
try:
callback(cls.user)
except:
logging.error("Error in online user callback", exc_info=True)
cls.online = []
答案 0 :(得分:1)
类LongPollingHandler(tornado.web.RequestHandler):
@ tornado.web.asynchronous
def get(self):
全球在线,计数,lastcount
self.connection_closed =错误
self.user = self.get_argument(“name”,None)
如果self.user不在线:
logging.info(“user:”+ self.user)
online.append(self.user)
http = tornado.httpclient.AsyncHTTPClient()
appURL = self.request.protocol +“://”+ self.request.host
http.fetch(appURL +“/ internal-polling”,self._on_finish)
'''push to the client'''
def _on_finish(self, response):
global online, count ,ipollcount
gone = self.request.connection.stream.closed()
print (self.user +" => " + str(gone))
if gone:
online.remove(self.user)
return
self.write("welcome %s, current online number(s) %s" % (self.user, response.body))
但是我刚刚在openshift的托管上遇到了问题(当客户端消失时我的localhost就可以了),我不知道龙卷风是否在代理后面,代理会在客户端之后切断连接。我也在寻找答案。