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