粉丝关系链,10亿数据,如何设计?
继续答星球水友提问,大数据量,高并发量,好友关系链、粉丝关系链要如何设计? 什么是关系链业务? 关系链主要分为两类,弱好友关系与强好友关系,两类都有典型的互联网产品应用。 弱好友关系的建立,不需要双方彼此同意:
idol与fans这类微博粉丝关系链,是一个典型的弱好友关系应用。 强好友关系的建立,需要好友关系双方彼此同意:
QQ好友关系链,是一个典型的强好友关系应用。 好友中心是一个典型的多对多业务:
其典型架构为:
弱好友关系,存储层应该如何实现? 通过弱好友关系业务分析,很容易了解到,其核心元数据为:
其中:
需要强调的是,一条弱关系的产生,会产生两条记录,一条关注记录,一条粉丝记录。 例如:用户A(uid=1)关注了用户B(uid=2),A多关注了一个用户,B多了一个粉丝,于是:
如何查询一个用户关注了谁?回答:在guanzhu的uid上建立索引:
即可得到结果,1关注了2。 如何查询一个用户粉了谁?回答:在fensi的uid上建立索引:
即可得到结果,2粉了1。 强好友关系,存储层应该如何实现? 方案一 通过强好友关系业务分析,很容易了解到,其核心元数据为:
其中:
uid=1的用户添加了uid=2的用户,双方都同意加彼此为好友,这个强好友关系,在数据库中应该插入记录{1, 2}还是记录{2,1}呢? 回答:都可以。为了避免歧义,可以人为约定,插入记录时uid1的值必须小于uid2。 例如:有uid=1,2,3三个用户,他们互为强好友关系,那边数据库中可能是这样的三条记录
如何查询一个用户的好友呢?回答:假设要查询uid=2的所有好友,只需在uid1和uid2上建立索引,然后:
即可得到结果。 方案二 强好友关系是弱好友关系的一个特例,A和B必须互为关注关系(也可以说,同时互为粉丝关系),即也可以使用关注表和粉丝表来实现:
例如:用户A(uid=1)和用户B(uid=2)为强好友关系,即相互关注: 用户A(uid=1)关注了用户B(uid=2),A多关注了一个用户,B多了一个粉丝,于是:
同时,用户B(uid=2)也关注了用户A(uid=1),B多关注了一个用户,A多了一个粉丝,于是:
两种实现,各有什么优缺点? 对于强好友关系的两类实现:
在数据量小时,看似无差异,但数据量大时,数据冗余的优势就体现出来了:
画外音:假如有10亿关系链,必须水平切分。 数据冗余,是多对多关系,在数据量大时,数据水平切分的常用实践。 如何进行数据冗余? 接下来的问题转化为,好友中心服务如何来进行数据冗余,常见有三种方法。 (编辑:ASP站长网) |