2

聊天室应用程序运行在多台服务器上,包含两个服务:
1. 连接管理器
在加入聊天室之前,客户端首先向连接管理器请求聊天服务 url
2. 聊天服务
一个典型的基于 socket.io 的聊天实现。

我需要将每个客户端的连接状态存储在 Redis 中,例如用户连接到哪个房间,一个房间有多少用户等。因此连接管理器可以使用这些数据进行负载平衡。

我可以使用socket连接/断开事件来维护Redis当前的连接状态,但是在NodeJS服务器出现故障的情况下,如何确保Node和Redis的数据是同步的呢?最好的方法是什么?

4

1 回答 1

1

我可以使用socket连接/断开事件来维护Redis当前的连接状态,但是在NodeJS服务器出现故障的情况下,如何确保Node和Redis的数据是同步的呢?

例如,您可以在 redis 中创建一个集合,其中包含对由特定服务器节点管理的键的引用。如果节点出现故障或重新启动,您可以使这些密钥无效。

于 2012-11-07T11:49:35.677 回答