
看图,有一台列表服务器,开了多个进程,放在 nginx 后面,多个进程从同一个 redis 里面共享数据。
其它服务器上有服务 A ,服务 B ,向列表服务器注册,并且每 3 秒发一次心跳,表明自己在线,如果 10 秒内列表服务器都没有收到心跳就认定这个服务离线了。列表服务器把每次心跳的时间存在 redis 里面供多进程共享。
用户向列表服务器请求的时候,返回可用的服务列表(实际上还包含一些其它的信息)。
想说的问题是,要有多台列表服务器的情况下,心跳包怎么办?
Plan A: 服务 A ,服务 B ,向每台列表服务器发心跳,但实际上第一次向列表服务器发心跳的时候,列表服务器会返回些内容,比如分配的一个 ID ,这时有多个列表服务器就不行了。虽然也可以向一台固定的列表服务器发第一个心跳,先拿到 ID 再向其它服务器发,但总觉得不好。
Plan B: redis 使用 master slave 来同步,其它服务仍然只向一台列表服务器发心跳,不知道是否可行。如果第一台列表服务器挂了怎么办。
各位怎么处理类似这样的例子的?