前言:“客户端上传时间戳”的玩法,你玩过么?一块儿聊聊时间戳的奇技淫巧!,其实这个相似于数据版本号的东西。服务器
缘起:无线时代,流量敏感。APP在登陆后,每每要向服务器同步很是多的数据,很费流量,技术上有没有节省流量的方法呢?这是本文要讨论的问题。微信
问题一:APP登陆时须要拉取什么数据?
答:APP登录时,通常要拉取两类数据,一类是“id列表型数据”,一类是“信息详情型数据”,以微信为例,须要拉取
(1)好友列表List<user-id>,即全部好友的id(id+name)
user_frined{uid, friend-uid, friend-name}
(2)群组列表List<group-id>,即全部加入群的id(id+name)
(3)群友列表Map<group-id, List<group-user-id>>,全部群友的id(id+name)
(4)好友详情Map<user-id, User>,全部好友的详情(昵称,备注,标签,地区,相册等)
user{uid, nick-name, memo, locate, tag}
(5)群组详情Map<group-id, Group>,全部群组的详情(二维码,公告,是否免打扰等)
(6)群友详情Map<group-id, Map<user-id, User>>,全部群友的详情(昵称,备注,标签,地区,相册等)
(7)其余,例如离线消息…网络
问题二:能不能在登陆的过程当中不拉取这些数据,而在登陆后拉取?
答:若是登陆时不拉取,登录后刷好友列表,刷群列表,群成员会很慢。
若是登陆时拉取,登录过程可能会很慢(微信的“大月亮背景”要等多长时间?QQ登陆要等30s?)。
为了保证登陆后的体验,通常是在登陆过程当中拉取。less
问题三:能不能直接复用客户端本地的数据?
答:不能直接复用客户端本地的数据,由于不能确保本地的数据是最新的。优化
核心问题:每次登陆都须要拉取,太费流量了,有没有优化方法?
答:经常使用优化方法有两种
(1)延迟拉取,按需拉取
(2)时间戳ui
问题五:延迟拉取,按需拉取为何有效?为何可以减小拉取流量?
答:用户在使用APP的过程当中,有些数据是必定会使用到的,有些数据是不必定会使用到的。对于必定会使用到的数据,登陆时拉取能够提高后续用户体验。对于不必定会使用到的数据,登陆时拉取可能浪费流量,这些数据若是进行“延迟拉取”,能够节省流量。同步
问题六:哪些数据不登陆后不必定会使用,能够延迟拉取?
答:这个问题的答案和业务紧密相关,以微信为例
必定会使用到的数据:好友列表(主页面要展现user-name),群组列表(主界面要展现group-name)
不必定会使用到的数据:好友详情,群组详情,群友列表,群友详情
故,对于微信,登陆时只须要拉取好友列表(id+name)与群组列表(id+name)便可,而其余数据,等用户真正点击和使用时再拉取便可,这样就能够大大减小拉取流量。登录
问题七:时间戳为何有效?为何可以减小拉取流量?
答:本地数据不能直接使用的缘由是,不肯定数据是否最新,拉取服务器时间戳与本地时间戳进行比对,若是本地是最新的数据,就能避免从新拉取。id列表数据的变化频度是比较低的(增长id,减小id),时间戳机制很是的有效。用户体验
问题八:加入时间戳机制后,数据拉取流程有什么变化?
答:假设有100个好友,以好友详情数据的拉取为例,没有时间戳以前,直接向服务器拉取这100个好友的详情数据。
在有了时间戳以后,数据拉取流程变为:
(1)先拉取100个好友的时间戳
(2)客户端将100个好友的时间戳与本地时间戳对比,找出差别,假设有10个好友的信息发生了变化,时间戳改变了
(3)拉取10个有变化的好友的信息
优势是:大大减小了数据传输量(由拉取100个好友,下降到拉取10个好友)
缺点是:增长了一次网络交互(原来直接拉取,如今须要分别拉取时间戳与差别数据)List
问题九:使用时间戳的同时,可否下降网络交互次数呢?
答:能够!
客户端对时间戳的使用,每每采起“客户端拉取时间戳”+“客户端比对时间戳”+“客户端再次拉取差别数据”的方式进行,“时间戳比对”的的CPU计算发生在客户端,其实,这个计算能够转嫁到服务器,步骤为:
(1)客户端上传100个好友的时间戳
(2)服务端收到客户端上传的时间戳,与最新时间戳对比,找出差别,假设有10个好友的信息发生了变化,服务端能够直接将有差别的10个好友的数据返回
优势是:客户端减小了一次网络请求
缺点是:比对时间戳差别的CPU计算由“端”转嫁到了“云”
问题十:你怎么知道微信是这么作的?
答:我不知道微信是怎么作的,微信比较出名,因此标题党了一把,抱歉。“客户端上传时间戳”的方法,58帮帮APP是这么作的,但愿对业界同仁有启示做用。
转自:http://www.habadog.com/2015/10/23/wechat-use-less-data/