问题描述
- 如何实现类似qq空间的“与我相关”动态即时提示功能?
-
项目要实现类似功能,目前我有三种实现方案,但总觉得并非上上之策,希望有过类似经验的朋友参与讨论?
方案1:APP用户点击后调用后台统计接口,传值至前台展示。
优点:实现简单,服务器性能消耗低。缺点:不能真正意义上实现即时通知。
方案二:服务器定时任务,根据情况推送动态。
优点:半即时推送,实现不难,缺点:消耗一定服务器性能
方案三:把活跃客户看成是一个活跃客户池, 由服务器主动去推送信息到客户端, 客户端接收到指令+数据后,去触发相应动作。如果客户端多的话, 可以把活跃客户看成是一个活跃客户池, 每台服务器从池里抓去自己负责的部分用户, 主动去推送信息到客户端。(如果客户量大,建议将客户池里区分开绑到不同服务器。 以保证每个服务器同时只处理等量的客户。)
优点:能够很好地满足需求,实现即时推送。缺点:实现难度大,服务器性能要求高。一些其他的想法:当数据表发生变动,即推送动态给APP用户,这应该是比较好的设计方案,运用MySQL触发器,但是我没找到数据表变化后立即执行代码的方式,请各位有这方面经验的朋友交流交流。
解决方案
客户端用websocket跟服务器建立通信。这样服务端可以主动push通知给客户端
服务端用一个优先级队列等得到最新消息。然后根据用户id等把消息推送到对应的客户端
时间: 2024-10-27 09:06:49