需求
文档编辑类型的需求,左侧是菜单栏,右侧是内容块,现在的需求时,如果多人同时编辑这个方案,当添加章节/调整章节顺序/删除章节时,其他用户能够及时感知到。
解决方案调研
前端轮询
最简单的方案,前端定时调用后端接口,使用短轮询或者长轮询都可以做到。麻烦的点可能在于,后端如何判定两次轮询之间数据的变化是否应该推给前端。
websocket
websocket可以维持前后端的长连接,实时同步各章节的更新情况,不需要记录历史情况,实时同步更新信号就可以。不过需要处理的连接逻辑可能会复杂一些。
EventSource
EventSource又称SSE(Server-Sent-Events),一种服务器端到客户端(浏览器)的单项消息推送方案,它和轮询一样,也是基于http请求来完成的。但是和轮询不一样的是它是服务器与客户端建立连接后,服务器主动的向客户端进行数据推送。
EventSource只能实现服务端向客户端推送消息。
SSE 要求服务器与浏览器保持连接。对于不同的服务器软件来说,所消耗的资源是不一样的。Apache 服务器,每个连接就是一个线程,如果要维持大量连接,势必要消耗大量资源。Node 则是所有连接都使用同一个线程,因此消耗的资源会小得多,但是这要求每个连接不能包含很耗时的操作,比如磁盘的 IO 读写。
问题
我们的诉求其实是能够让客户端接收到数据变更的消息,感觉EventSource可以考虑一下。
但是对于java开发的应用来说,EventSource的资源消耗感觉和websocket不相上下?
如果读者有啥更好的解决方案,可以评论告诉我。