web server 不同服务器之间的通信问题

2016-11-01 16:19:17 +08:00
 bluesky139

看图,有一台列表服务器,开了多个进程,放在 nginx 后面,多个进程从同一个 redis 里面共享数据。

其它服务器上有服务 A ,服务 B ,向列表服务器注册,并且每 3 秒发一次心跳,表明自己在线,如果 10 秒内列表服务器都没有收到心跳就认定这个服务离线了。列表服务器把每次心跳的时间存在 redis 里面供多进程共享。

用户向列表服务器请求的时候,返回可用的服务列表(实际上还包含一些其它的信息)。

想说的问题是,要有多台列表服务器的情况下,心跳包怎么办?

Plan A: 服务 A ,服务 B ,向每台列表服务器发心跳,但实际上第一次向列表服务器发心跳的时候,列表服务器会返回些内容,比如分配的一个 ID ,这时有多个列表服务器就不行了。虽然也可以向一台固定的列表服务器发第一个心跳,先拿到 ID 再向其它服务器发,但总觉得不好。

Plan B: redis 使用 master slave 来同步,其它服务仍然只向一台列表服务器发心跳,不知道是否可行。如果第一台列表服务器挂了怎么办。

各位怎么处理类似这样的例子的?

3848 次点击
所在节点    程序员
8 条回复
clino
2016-11-01 16:30:16 +08:00
redis 不能共用一个吗?
有多个 web 应用服务器多个 nginx,但只同时连同一个 redis 做缓存
bluesky139
2016-11-01 16:34:35 +08:00
@clino 我现在是直接以同步的方式操作 redis (因为 redis 够快,还没有卡在这个地方),如果共用一个 redis ,要跨机器,那就得改成异步的?
sherlocktheplant
2016-11-01 16:37:39 +08:00
@bluesky139 redis 单独开一台或者多台机器不就行了?
bluesky139
2016-11-01 16:55:35 +08:00
@sherlocktheplant redis 放单独机器上需要异步去查询,反而觉得慢了。
ibigbug
2016-11-01 16:58:07 +08:00
把 nginx 和 redis 拆出来,进程 1...进程 N 就能水平扩展了,也可以是机器 1...机器 N ,这种无状态是最方便的。

跨机器不一定非要是异步的,同机房网络延迟 10ms 左右可以接受。

大规模应用别说跨机器了,跨机房、跨地区调用都是有的。
rrfeng
2016-11-01 17:05:39 +08:00
这不就是个服务注册器么,请把 redis 换成 zookeeper / etcd
clino
2016-11-01 17:12:17 +08:00
@bluesky139 我觉得应该可以不用异步的,你可以测试下同步做法下性能能不能接受
chocotan
2016-11-02 08:58:03 +08:00
zookeeper+1

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/317126

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX