如何设计可以动态扩容缩容的分库分表方案.docxVIP

如何设计可以动态扩容缩容的分库分表方案.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
如何设计可以动态扩容缩容的分库分表方案 周国睿 2021-11-28 停机扩容(不推举) 这个方案就跟停机迁移一样,步骤几乎全都,独一的一点就是那个导数的工具,是把现有库表的数据抽出来渐渐倒入到新的库和表里去。但是最好别这么玩儿,有点不太靠谱,由于既然分库分表就说明数据量实在是太大了,可能多达几亿条,甚至几十亿,你这么玩儿,可能会出问题。 从单库单表迁移到分库分表的时候,数据量并不是很大,单表最大也就两三千万。那么你写个工具,多弄几台机器并行跑,1小时数据就导完了。这没有问题。 假如 3 个库 + 12 个表,跑了一段时间了,数据量都 1~2 亿了。光是导 2 亿数据,都要导个几个小时,6 点,刚刚导完数据,还要搞后续的修改配置,重启系统,测试验证,10 点才可以搞完。所以不能这么搞。 优化后的方案 一开头上来就是 32 个库,每个库 32 个表,那么总共是 1024 张表。 我可以告知各位同学,这个分法,第一,基本上国内的互联网确定都是够用了,其次,无论是并发支撑还是数据量支撑都没问题。 每个库正常承载的写入并发量是 1000,那么 32 个库就可以承载32 * 1000 = 32000 的写并发,假如每个库承载 1500 的写并发,32 * 1500 = 48000 的写并发,接近 5 万每秒的写入并发,前面再加一个MQ,削峰,每秒写入 MQ 8 万条数据,每秒消费 5 万条数据。 有些除非是国内排名格外靠前的这些公司,他们的最核心的系统的数据库,可能会消灭几百台数据库的这么一个规模,128个库,256个库,512个库。 1024 张表,假设每个表放 500 万数据,在 MySQL 里可以放 50 亿条数据。 每秒 5 万的写并发,总共 50 亿条数据,对于国内大部分的互联网公司来说,其实一般来说都够了。 谈分库分表的扩容,第一次分库分表,就一次性给他分个够,32 个库,1024 张表,可能对大部分的中小型互联网公司来说,已经可以支撑好几年了。 一个实践是利用?32 * 32?来分库分表,即分为 32 个库,每个库里一个表分为 32 张表。一共就是 1024 张表。依据某个 id 先依据 32 取模路由到库,再依据 32 取模路由到库里的表。 orderId id % 32 (库) id / 32 % 32 (表) 259 3 8 1189 5 5 352 0 11 4593 17 15 刚开头的时候,这个库可能就是规律库,建在一个数据库上的,就是一个mysql服务器可能建了 n 个库,比如 32 个库。后面假如要拆分,就是不断在库和 mysql 服务器之间做迁移就可以了。然后系统协作改一下配置即可。 比如说最多可以扩展到32个数据库服务器,每个数据库服务器是一个库。假如还是不够?最多可以扩展到 1024 个数据库服务器,每个数据库服务器上面一个库一个表。由于最多是1024个表。 这么搞,是不用本人写代码做数据迁移的,都交给 dba 来搞好了,但是 dba 的确是需要做一些库表迁移的工作,但是总比你本人写代码,然后抽数据导数据来的效率高得多吧。 哪怕是要削减库的数量,也很简约,其实说白了就是按倍数缩容就可以了,然后修改一下路由规章。 这里对步骤做一个总结: 设定好几台数据库服务器,每台服务器上几个库,每个库多少个表,推举是 32库 * 32表,对于大部分公司来说,可能几年都够了。 路由的规章,orderId 模 32 = 库,orderId / 32 模 32 = 表 扩容的时候,申请添加更多的数据库服务器,装好 mysql,呈倍数扩容,4 台服务器,扩到 8 台服务器,再到 16 台服务器。 由 dba 担任将原先数据库服务器的库,迁移到新的数据库服务器上去,库迁移是有一些便捷的工具的。 我们这边就是修改一下配置,调整迁移的库所在数据库服务器的地址。 重新发布系统,上线,原先的路由规章变都不用变,直接可以基于 n 倍的数据库服务器的资源,连续进行线上系统的供应服务。

文档评论(0)

liuxiyuliuxingyu + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档