看图,有一台列表服务器,开了多个进程,放在 nginx 后面,多个进程从同一个 redis 里面共享数据。
其它服务器上有服务 A ,服务 B ,向列表服务器注册,并且每 3 秒发一次心跳,表明自己在线,如果 10 秒内列表服务器都没有收到心跳就认定这个服务离线了。列表服务器把每次心跳的时间存在 redis 里面供多进程共享。
用户向列表服务器请求的时候,返回可用的服务列表(实际上还包含一些其它的信息)。
想说的问题是,要有多台列表服务器的情况下,心跳包怎么办?
Plan A: 服务 A ,服务 B ,向每台列表服务器发心跳,但实际上第一次向列表服务器发心跳的时候,列表服务器会返回些内容,比如分配的一个 ID ,这时有多个列表服务器就不行了。虽然也可以向一台固定的列表服务器发第一个心跳,先拿到 ID 再向其它服务器发,但总觉得不好。
Plan B: redis 使用 master slave 来同步,其它服务仍然只向一台列表服务器发心跳,不知道是否可行。如果第一台列表服务器挂了怎么办。
各位怎么处理类似这样的例子的?
1
clino 2016-11-01 16:30:16 +08:00
redis 不能共用一个吗?
有多个 web 应用服务器多个 nginx,但只同时连同一个 redis 做缓存 |
2
bluesky139 OP @clino 我现在是直接以同步的方式操作 redis (因为 redis 够快,还没有卡在这个地方),如果共用一个 redis ,要跨机器,那就得改成异步的?
|
3
sherlocktheplant 2016-11-01 16:37:39 +08:00
@bluesky139 redis 单独开一台或者多台机器不就行了?
|
4
bluesky139 OP @sherlocktheplant redis 放单独机器上需要异步去查询,反而觉得慢了。
|
5
ibigbug 2016-11-01 16:58:07 +08:00
把 nginx 和 redis 拆出来,进程 1...进程 N 就能水平扩展了,也可以是机器 1...机器 N ,这种无状态是最方便的。
跨机器不一定非要是异步的,同机房网络延迟 10ms 左右可以接受。 大规模应用别说跨机器了,跨机房、跨地区调用都是有的。 |
6
rrfeng 2016-11-01 17:05:39 +08:00
这不就是个服务注册器么,请把 redis 换成 zookeeper / etcd
|
7
clino 2016-11-01 17:12:17 +08:00
@bluesky139 我觉得应该可以不用异步的,你可以测试下同步做法下性能能不能接受
|
8
chocotan 2016-11-02 08:58:03 +08:00
zookeeper+1
|