为什么社交网络中数据翻页技术复杂-技术方案

时间:14-12-15 栏目:大数据 作者:爱说云网 评论:0 点击: 1,312 次

最近讨论的一个传统的问题,问题本身比较简单,针对key-list类型的数据,如何优化方案做到性能与成本的tradeoff。Key-list 在社交产品及面向用户的产品中非常普遍,如一个用户的好友关系 {“uid”:{1,2,3,4,5}},表示某个uid有1,2,3,4,5好友;一条微博下面的评论id列表结构是 {“weibo_id”: {comment_id1, comment_id2……}},一个用户发表的微博id列表等。

  在list长度较小时,我们可以直接使用数据库的翻页功能,如

  SELECT * FROM LIST_TABLE LIMIT offset, row_count;

  根据经验,在大部分场景下,单个业务的list数据长度99%的情况在1000条以下,在数据规模较小时,上面的方法非常适合。但剩下的1%情况下,数据可能多达100万条,在数据规模较大的时候,当访问offset较大的数据集,上述方法非常低效。但在考虑方案的时候不能忽视这些超大数据集的问题,因此要实现一个适合各种变长list场景的翻页方案,业界并没有简单高效的方案。这也反映出常说的80%的时间在优化20%的功能。

  List数据访问模型常见的有两种方式

  1. 扶梯方式

  扶梯方式在导航上通常只提供上一页/下一页这两种模式,部分产品甚至不提供上一页功能,只提供一种“更多/more”的方式,也有下拉自动加载更多的方式,在技术上都可以归纳成扶梯方式。

  (图:blogspot的导航条)

  (图:很多瀑布流式的产品只提供一个more的导航条)

  扶梯方式在技术实现上比较简单及高效,根据当前页最后一条的偏移往后获取一页即可,在MySQL可使用以下方法实现。

  SELECT * FROM LIST_TABLE WHERE id > offset_id LIMIT n;

  由于where条件中指定了位置,根据B-TREE实现原理,算法复杂度是O(log n)

  2. 电梯方式

  另外一种数据获取方式在产品上体现成精确的翻页方式,如1,2,3……n,同时在导航上也可以由用户输入直达n页。国内大部分产品经理对电梯方式有特殊的喜好,如图

  (图:timyang.net 网站的导航条)

  但电梯方式在技术实现上相对成本较高,当使用以下SQL时

  SELECT * FROM LIST_TABLE LIMIT offset, row_count;

  我们可以使用MySQL explain来分析,从下文可以看到,当offset=10000时候,实际上MySQL也扫描了10000行记录。

  为什么会这样?在MySQL中,索引通常是b-tree方式(但存储引擎如InnoDB实际是b+tree),如图

  从图中可以看到,使用电梯方式时候,当用户指定翻到第n页时候,并没有直接方法寻址到该位置,而是需要从第一楼逐个count,scan到count*page时候,获取数据才真正开始,所以导致效率不高。对应的算法复杂度是O(n),n指offset,也就是page*count。

  另外Offset并不能有效的缓存以便转化成前一种访问模式,这是由于

  1、在数据存在新增及删除的情况下,只要有一条变化,原先的楼层可能会全部发生变化。在一个用户并发访问的场景,频繁变化的场景比较常见。

  2、电梯使用比较离散,可能一个20万条的list,用户使用了一次电梯直达100楼之后就走了,这样即使缓存100楼之下全部数据也不能得到有效利用。

  以上描述的场景属于单机版本,在数据规模较大时候,互联网系统通常使用分库的方式来保存,实现方法更为复杂。在面向用户的产品中,数据分片通常会将同一用户的数据存在相同的分区,以便更有效率的获取当前用户的数据。如下图所示

  图中的不同年份的数据的格子是逻辑概念,实际上同一用户的数据是保存在一张表中。因此方案在常见的使用场景中存在很大不足,大部分产品用户只访问最近产生的数据,历史的数据只有极小的概率被访问到,因此同一个区域内部的数据访问是非常不均匀,如图中2014年生成的属于热数据,2012年以前的属于冷数据,只有极低的概率被访问到。但为了承担红色部分的访问,数据库通常需要高速昂贵的设备如SSD,因此上面方案所有的数据都需要存在SSD设备中,即使这些数据已经不被访问。

  简单的解决方案是按时间远近将数据进行进一步分区,如图。

  注意在上图中使用时间方式sharding之后,在一个时间分区内,也需要用前一种方案将数据进行sharding,因为一个时间片区通常也无法用一台服务器容纳。

  上面的方案较好的解决了具体场景对于key list访问性能及成本的tradeoff,但是它存在以下不足

  1、数据按时间进行滚动无法全自动,需要较多人为介入或干预

  2、数据时间维度需要根据访问数据及模型进行精巧的设计,如果希望实现一个公用的key-list服务来存储所有业务的数据,这个公用服务可能很难实现

  3、为了实现电梯直达功能,需要增加额外的二级索引,比如2013年某用户总共有多少条记录

  由于以上问题,尤其是二级索引的引入,显然它不是理想中的key list实现,后文继续介绍适合长尾翻页key list设计的一些思路及尝试。

相关文章

云计算“三国时代”:百度有开发者,阿里靠中间人,腾讯要突围...
views 1665
云计算“三国时代”:百度有开发者,阿里靠中间人,腾讯要突围   自从2013年9月腾讯云推出之后,中国云计算市场正式进入三国时代。尽管微软、亚马逊云服务均已入华,中国三大运营商也有云计算产品,京东、新浪等“小巨头”也有云计算产品,但相比三大互联网巨头而言,它们并没有多少存在感。云计算不...
【新闻晨报】互联网巨头为什么突然盯上了免费WiFi?...
views 1312
中云网每天精选各科技媒体头条! 1.腾讯科技 印度互联网创业大热:会出现“下一个苹果”? http://tech.qq.com/a/20141219/009694.htm 印度已经俨然成为科技巨头的掘金圣地。 本周三,印度最大的买房租房网站Housing.com宣布融资9000万美元,由日本软银领投...
我们为什么爱EC2和S3却彻底抛弃EBS?
views 2405
awe.sm从创立之初就采用了AWS平台,过去3年我们体验了AWS的优美和不足,并总结出一套最佳实践。 不夸张的说,AWS彻底改变了科技创业公司的经济运行模式。没有人意识到有多少公司正在使用AWS的EC2,直到它发生宕机“真相”才浮出水面。每个人使用AWS都可以从根本上实现非常简单的运行软件的方式,...
云计算:程序员重回个人英雄时代 -
views 1242
曾几何时,那些耳熟能详的程序英雄的名字渐渐地离我们远去。随着Windows和Internet时代的来临,个人的力量变得越来越渺小。正当我们开始坚信单打独斗的时代一去不复返的时候,云计算横空出世了。它强大的计算能力、存储能力和简单高效的编程接口,使得一位程序员能够轻松地操控成千上万台计算机,而不必考虑...
城市智能需求上升物联网在其有何贡献-国内...
views 1795
随着城市的扩展,公共产所设施的完善,以及人口数量的增多,社会安防交通压力也随之而增。交通问题的解决从单一的安防产品向系统解决方案发展,以科技与互联网为基础的指南通道安防系统已成为趋势,遍及校园、社区、景点等多个领域。   国家《物联网“十二五”发展规划》中明确指出:“在重点领域开展应用示范工程,探...
百度大数据洞察:“数”说年轻女性的自我世界-应用案例...
views 1497
  百度大数据带您透视小世界里的大女人精神。小世界指的是新一代年轻女性的自我世界,寓意每一个小小的我都是一个世界;大女人寓意新一代年轻女性脱离集体意识形态,不再完全秉承传统女性小鸟依人式的附属与顺从,而体现为一种独立自主的精神、一种大女人的情怀。   新一代年轻女性自我意识崛起下的3个需求层次  ...
到底要不要选择BaaS?看情况吧
views 1555
备份即服务(BaaS)从云端提供了备份和恢复操作。基于云的BaaS提供商在其数据中心维持一套必不可少的备份设备、应用软件、流程和管理。客户要在本企业安装一些系统――通常是硬件设备和备份代理,但根本不需要购买备份服务器和软件,不需要什么升级、打补丁,也不需要购买重复数据删除专用设备。 请注意:Baa...
大数据与网络黑产
views 2707
随着互联网不断深度介入人们的生活,网络上也在源源不断积累起大量数据。这些数据就像散落在互联网生态中的粒粒珍珠,诱惑着网络黑产分子瞪大贪婪的双眼,伺机而动…… 记者调查发现,基于这些存在的产业链,上游,是以技术含量最高的职业黑客为主,他们通过挖掘漏洞、编写木马实施入侵,获取数据;中游,是购买这些数据...

声明: 本文由( 爱说云网 )原创编译,转载请保留链接: 为什么社交网络中数据翻页技术复杂-技术方案

为什么社交网络中数据翻页技术复杂-技术方案:等您坐沙发呢!

发表评论


读者排行