我有一个Tornado Websocket服务器,它有一个开放式连接字典:
class WebSocketHandler(tornado.websocket.WebSocketHandler):
def open(self, *args):
self.id = self.generate_id()
self.stream.set_nodelay(True)
# ... DO STUFF ...
clients[self.id] = {"id": self.id, "time":datetime.now(), "object": self}
self.write_message("Connection SUCCESSFUL! Thanks for connecting! Your connection ID is: %d :)" % self.id)
print datetime.now()
print "New connection. ID: %d" % self.id
print "Total number of open connections: %d" % len(clients)
def on_close(self):
print datetime.now()
print "Closing connection %d." % self.id
if self.id in clients:
del clients[self.id]
print "Number of open connections: %d" % len(clients)
我想自动关闭超过一个小时的所有连接。所以像这样:
for client in clients.values():
if (datetime.now() - client["time"])>timedelta(minutes=60):
client["object"].close()
但我不知道应该把这张支票放在哪里并关闭旧连接。
答案 0 :(得分:2)
有关进一步说明,请参阅this answer
import tornado
import datetime
class WebSocketHandler(tornado.websocket.WebSocketHandler):
def open(self, *args):
self.id = self.generate_id()
self.stream.set_nodelay(True)
self.timeout = tornado.ioloop.IOLoop.current().add_timeout(
datetime.timedelta(minutes=60), self.explicit_close)
# ... DO STUFF ...
clients[self.id] = {"id": self.id, "time":datetime.now(), "object": self}
self.write_message("Connection SUCCESSFUL! Thanks for connecting! Your connection ID is: %d :)" % self.id)
print datetime.now()
print "New connection. ID: %d" % self.id
print "Total number of open connections: %d" % len(clients)
def on_close(self):
print datetime.now()
print "Closing connection %d." % self.id
if self.id in clients:
del clients[self.id]
print "Number of open connections: %d" % len(clients)
def explicit_close(self):
self.close() # you wont even have to iterate over the clients.
关注龙卷风的IOLoop和reference question,这将很容易理解。