业界难题-“跨库分页”的四种方案 学习笔记

微信公共号 [架构师之路] 上看到一篇文章 业界难题-“跨库分页”的四种方案,学习了下,一些笔记。

分页需求

互联网很多业务都有分页拉取数据的需求,例如:京东下单过多时,拉取第 N 页订单。

这些业务场景对应的分页拉取需求有这样一些特点:
(1)有一个业务主键, 例如 order_id
(2)分页排序是按照非业务主键来排序的,例如 time

在数据量不大时,可以通过在排序字段 time上建立索引,利用SQL提供的 offset/limit 功能就能满足分页查询需求:
select * from t_order order by time offset 200 limit 100
此处假设一页数据为 100 条,均拉取第 3 页数据

分库需求

随着数据量的增大,数据库需要进行水平切分,分库后将数据分布到不同的数据库实例(甚至物理机器)上。
一旦涉及分库,逃不开 “分库依据” partition key 的概念。
大部分的业务场景,会使用 业务主键 id 取模的算法来分库,这样即能够保证每个库的数据分布是均匀的,又能够保证每个库的请求分布是均匀的。

例如:
用户库 user,水平切分后变为两个库,分库依据 partition key 是 uid。
分库算法是 uid 取模:uid%2 余 0 的数据会落到 db0,uid%2 余 1 的数据会落到 db1。


业务主键 uid 取模的算法来分库

如果业务要查询 “最近注册的第3页用户”,该如何实现呢?
单库上,可以 select * from t_user order by time offset 200 limit 100

变成两个库后,分库依据是 uid,排序依据是 time,数据库层失去了 time 排序的全局视野,数据分布在两个库上,此时该怎么办呢?

方案一 全局视野法

全局视野法

如上图所述,服务层通过 uid 取模将数据分布到两个库上去之后,每个数据库都失去了全局视野,数据按照 time 局部排序之后,不管哪个分库的第 3 页数据,都不一定是全局排序的第 3 页数据。

必须每个库都返回全部 3 页数据,所得到的全部 6 页数据在服务层进行内存排序,得到数据全局视野,再取第 3 页数据,便能够得到想要的全局分页数据。

总结一下这个方案的步骤:

  1. order by time offset X limit Y,改写成 order by time offset 0 limit X+Y
  • 服务层将改写后的 SQL 语句发往各个分库:即例子中的各取 3 页数据
  • 假设共分为 N 个库,服务层将得到 N*(X+Y) 条数据:即例子中的 6 页数据
  • 服务层对得到的 N*(X+Y) 条数据进行内存排序,内存排序后再取偏移量 X 后的 Y 条记录,就是全局视野所需的一页数据

方案优点:能够得到全局视野,业务无损,精准返回所需数据。
方案缺点:

  1. 每个分库需要返回更多的数据
  • 除了数据库按照 time 进行排序,服务层还需要进行二次排序
  • 最致命的,这个算法随着页码的增大,性能会急剧下降

方案二 业务折衷法

任何脱离业务的架构设计都是耍流氓,技术方案需要折衷,在技术难度较大的情况下,业务需求的折衷能够极大的简化技术方案。

业务折衷一:禁止跳页查询

在数据量很大,翻页数很多的时候,很多产品并不提供 “直接跳到指定页面” 的功能,而只提供 “下一页” 的功能,这一个小小的业务折衷,就能极大的降低技术方案的复杂度。


禁止跳页查询

如上图,不够跳页,那么第一次只能够查第一页:

  1. 将查询 order by time offset 0 limit 100,改写成 order by time where time>0 limit 100
  • 服务层得到 2 页数据,内存排序,取出前 100 条数据,作为最终的第一页数据
  • 点击 “下一页” 时,需要拉取第二页数据,在第一页数据的基础之上,能够找到第一页数据 time 的最大值 time_max
    将查询改写成 order by time where time>$time_max limit 100
  • 服务层得到 2 页数据,内存排序,取出前 100 条数据,作为最终的第 2 页数据
  • 依次类推,即使点击 100 次 “下一页”,每次每个数据库也只是返回 100 条数据,服务层每次对 200 条数据做排序。以保证数据的传输量和排序的数据量不会随着不断翻页而导致性能下降。

业务折衷二:允许数据精度损失

使用 partition key 进行分库,在数据量较大,数据分布足够随机的情况下,各分库所有非 partition key 属性,在各个分库上的数据分布,统计概率情况是一致的。

利用这一原理,要查询全局 100 页数据,offset 9900 limit 100 改写为 offset 4950 limit 50,每个分库偏移 4950(一半),获取 50 条数据(半页),得到的数据集的并集,基本能够认为,是全局数据的 offset 9900 limit 100 的数据,当然,这一页数据的精度,并不是精准的。

根据实际业务经验,用户都要查询第 100 页网页、帖子、邮件的数据了,这一页数据的精准性损失,业务上往往是可以接受的,但此时技术方案的复杂度便大大降低了,既不需要返回更多的数据,也不需要进行服务内存排序了。

方案三 二次查询法

有点复杂,详见原文。


引用:
业界难题-“跨库分页”的四种方案

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容

  • 一、需求缘起 分页需求 互联网很多业务都有分页拉取数据的需求,例如: (1)微信消息过多时,拉取第N页消息 (2)...
    duzhongli阅读 448评论 0 3
  • 互联网很多业务都有分页拉取数据的需求,业务中经常按照时间time来排序order by,在数据量不大时,可以通过在...
    米刀灵阅读 2,270评论 0 7
  • 需要原文的可以留下邮箱我给你发,这里的文章少了很多图,懒得网上粘啦 1数据库基础 1.1数据库定义 1)数据库(D...
    极简纯粹_阅读 7,406评论 0 46
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,633评论 18 139
  • 今天儿子在每日管理中,因为练字和背诵经典哪里有多次空缺,我没有用对方法也没有控制住自己的脾气,让孩子很伤心...
    何金霖阅读 181评论 0 0