直播推荐页面的刷新机制

直播类APP的推荐页面和一般信息展示类的界面有所区别的一点是:要求信息的实时更新.尽量去避免界面上信息的不准确,比如:
1.主播已经关播了,而界面上仍然显示该主播,观众点进去却得不到想要的结果,体验并不好;
2.主播的热度得不到更新,在推荐上顺序得不到及时的更新;

当考虑到信息的时效性,有效的优化细节,考虑了几个方案:
1,使用socket长连接与Http相结合的方式.Http用来请求整个列表,针对场景为:刷新整个列表.长连接是由后台来推送某一个主播或几个主播更新后的信息,比如是否关播,热度,顺序等,这种情形下,前端显示需要处理的情况相当多,比如调整列表顺序,这就存在很多的问题(一个本来在中间的主播调整到首位的需求,我们需要先通过ID找到这个主播,然后调整位置,关键在于找到需要使用循环,那么问题来了当列表里主播越多需要循环的次数就越多,多主播位置变动的时候,频繁度和复杂度又升级了,当我一个循环还没走完,另外一个长连接信息来了...)这种对于前端来讲非常被动的处理方式,实时性高,复杂度高,消耗大,开发时间充足且逻辑处理能力强的可以尝试.

2,Http单轮询的方式.这种方式很多人都能想到,定时器跑一个,时间间隔短一点,拉取用户列表.但是可能没有考虑周详,我们的主播列表如果有500条信息(这么大的信息量肯定在服务器端压缩过),每10s,20s拉取有一次,后台压力会非常大.那分页呢,抱歉,分页虽然数据少了,但是在要求失效性的情形下不可能(如果A主播开始在第一页,之后服务器数据更新,将A放到了第二页,那用户在拉取第二页的时候又出现了A,那么我们要做排重吗,第二页信息每一个在加入列表的前都要遍历一遍?)

3,Http双轮询的方式.这是我们目前使用的方式,每10s种拿到当前用户停留位置上下共6-7个用户的ID,发给服务器,服务器返回针对这几个用户需要更新的数据.同时120s刷新整个列表一次.实时性不高,复杂度低,用户体验方面也可以.能够满足需求.用户整体排序依赖于用户主动下拉刷新以及后台正列表轮训,并且相对于上次拉取整个列表时间在60s内的请求进行拦截.

对于小公司来说节省服务器资源还是很有必要的,我们APP刚上线的时候,因为开发周期短,很多问题没解决匆匆上线,服务器爆掉好几次~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,992评论 19 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,558评论 25 708
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 11,185评论 6 13
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,257评论 4 61
  • 【淘淘作业本】2017年3月5日 作业一:发掘空性 老公晚上老是跟儿子玩的很晚都不睡觉。 1、一切都是对的。 老公...
    淘淘的简书阅读 180评论 0 0