原文地址:http://blog.720ui.com/2017/mysql_core_09_multi_db_table2/

随着用户数的不断增加,以及数据量的不断增加,通过分库与分表的方式提高查询性能的同时,带来了一系列分布式困境。

数据迁移与扩容问题

前面介绍到水平分表策略归纳总结为随机分表和连续分表两种情况。连续分表有可能存在数据热点的问题,有些表可能会被频繁地查询从而造成较大压力,热数据的表就成为了整个库的瓶颈,而有些表可能存的是历史数据,很少需要被查询到。连续分表的另外一个好处在于比较容易,不需要考虑迁移旧的数据,只需要添加分表就可以自动扩容。随机分表的数据相对比较均匀,不容易出现热点和并发访问的瓶颈。但是,分表扩展需要迁移旧的数据。
针对于水平分表的设计至关重要,需要评估中短期内业务的增长速度,对当前的数据量进行容量规划,综合成本因素,推算出大概需要多少分片。对于数据迁移的问题,一般做法是通过程序先读出数据,然后按照指定的分表策略再将数据写入到各个分表中。

表关联问题

在单库单表的情况下,联合查询是非常容易的。但是,随着分库与分表的演变,联合查询就遇到跨库关联和跨表关系问题。在设计之初就应该尽量避免联合查询,可以通过程序中进行拼装,或者通过反范式化设计进行规避。

分页与排序问题

一般情况下,列表分页时需要按照指定字段进行排序。在单库单表的情况下,分页和排序也是非常容易的。但是,随着分库与分表的演变,也会遇到跨库排序和跨表排序问题。为了最终结果的准确性,需要在不同的分表中将数据进行排序并返回,并将不同分表返回的结果集进行汇总和再次排序,最后再返回给用户。

分布式事务问题

随着分库与分表的演变,一定会遇到分布式事务问题,那么如何保证数据的一致性就成为一个必须面对的问题。目前,分布式事务并没有很好的解决方案,难以满足数据强一致性,一般情况下,使存储数据尽可能达到用户一致,保证系统经过一段较短的时间的自我恢复和修正,数据最终达到一致。

分布式全局唯一ID

在单库单表的情况下,直接使用数据库自增特性来生成主键ID,这样确实比较简单。在分库分表的环境中,数据分布在不同的分表上,不能再借助数据库自增长特性。需要使用全局唯一 ID,例如 UUID、GUID等。关于如何选择合适的全局唯一 ID,我会在后面的章节中进行介绍。

总结

分库与分表主要用于应对当前互联网常见的两个场景:海量数据和高并发。然而,分库与分表是一把双刃剑,虽然很好的应对海量数据和高并发对数据库的冲击和压力,但是却提高的系统的复杂度和维护成本。

因此,我的建议:需要结合实际需求,不宜过度设计,在项目一开始不采用分库与分表设计,而是随着业务的增长,在无法继续优化的情况下,再考虑分库与分表提高系统的性能。

分库与分表带来的分布式困境与应对之策相关推荐

  1. access 分表存储_sharding:谁都能读懂的分库、分表、分区

    本文通过大量图片来分析和描述分库.分表以及数据库分区是怎样进行的. 1.sharding前的初始数据分布 在本文中,我打算用高考考生相关信息作为实验数据.请无视表的字段是否符合现实,也请无视表的设计是 ...

  2. 分库分表原因,分库分表的方式,分库分表带来的问题

    分库分表 1 为什么分库分表 ​ 随着平台的业务发展,数据可能会越来越多,甚至达到亿级.以MySQL为例,单库数据量在5000万以内性能比较好,超过阈值后性能会随着数据量的增大而明显降低.单表的数据量 ...

  3. 【转载】分布式数据库架构--分库、分表、排序、分页、分组、实现

    MySQL分库分表总结: 单库单表 : 单库单表是最常见的数据库设计,例如,有一张用户(user)表放在数据库db中,所有的用户都可以在db库中的user表中查到. 单库多表 : 随着用户数量的增加, ...

  4. mysql分布式数据库架构_MySQL分布式数据库架构:分库、分表、排序、分页、分组、实现教程...

    MySQL分库分表总结: 单库单表 : 单库单表是最常见的数据库设计,例如,有一张用户(user)表放在数据库db中,所有的用户都可以在db库中的user表中查到. 单库多表 : 随着用户数量的增加, ...

  5. 分布式数据库架构--分库、分表、排序、分页、分组、实现

    MySQL分库分表总结: 单库单表 : 单库单表是最常见的数据库设计,例如,有一张用户(user)表放在数据库db中,所有的用户都可以在db库中的user表中查到. 单库多表 : 随着用户数量的增加, ...

  6. MySQL分库、分表、分区的区别

    1.1 分 很多技术都运用了分的编程思想,这里来举几个例子,这些都是分的思想 集中式服务发展到分布式服务 从Collections.synchronizedMap(x)到1.7ConcurrentHa ...

  7. 10分钟速解 | 大型分布式电商系统架构

    关注公众号"Java后端技术全栈" 回复"电子书"获取程序员必备电子书 hi,大家好,今天是周四了,明天就开始国庆长假了. 提前祝大家国庆快乐!也祝祖国繁荣富强 ...

  8. 【分库、分表】MySQL分库分表方案

    一.Mysql分库分表方案 1.为什么要分表: 当一张表的数据达到几千万时,你查询一次所花的时间会变多,如果有联合查询的话,我想有可能会死在那儿了.分表的目的就在于此,减小数据库的负担,缩短查询时间. ...

  9. mysql大数据分库和分表 php解决方案

    当Mysql数据量过大时,就会面临压力分解,这时分库分表是一个不错的解决方案,现在我们就来谈谈Mysql如何分库分表比较理想,然后再用php如何调用. 1,主从复制,读写分离 对主库修改数据,查询使用 ...

最新文章

  1. 坐在隔壁的00后同事,让我看到了职场“反内卷”的希望
  2. BZOJ3743 COCI2015Kamp(树形dp)
  3. 全球与中国除颤监护仪市场深度调研与未来前景研究报告2022-2027年版
  4. 僧多粥少?还原 OpenStack 的真实“钱景”
  5. java反射头文件_编程基础知识——C++能不能支持Java和ObjC的反射?
  6. leetcode 168. Excel表列名称
  7. Linux下Java的安装与配置
  8. PostgreSQL修改pgsql提示符
  9. java list转数组_java list 转数组
  10. 修改linux文本模式下的分辨率
  11. Servlet(1) Servlet容器和Servlet
  12. sql身份证号计算年龄_函数
  13. xp谷歌浏览器时间快了_Win7系统零日漏洞曝光,谷歌建议:升级Windows 10
  14. 单片机74LS164C语言例子,74ls164单片机编程汇总(跑马灯/驱动数码管)
  15. 圆柱体的表面积,三位数反转,交换变量
  16. 爬取网易云音乐评论,破解网易云加密算法
  17. 统一服务消息 【公众号和小程序 模板消息下发统一openId解惑】
  18. 搭建gos_快速浏览gOS –但不要称其为Google
  19. 第二课 介绍:手绘墙画颜料选择
  20. .NET 高级架构师0003 架构师之路(2)---架构师的职责

热门文章

  1. 广和通l610二次开发|广和通l610 CAT.1模组opencpu开发《二》cola_os移植
  2. 广和通5G模组FM650-CN在Win11下的短信和通话演示
  3. 企业微信审批页面HTML,企业微信审批模板调用示例及注意事项
  4. 小甲鱼第一课(分支、字符串)
  5. 基于Flask+bootstrap+sqlite开发宝宝成长管理系统,宝宝成长记录系统源码
  6. offset、事件对象、事件鼠标的坐标、键盘事件、输入框放大显示的案例
  7. 什么是价值琏分析法以及价值链分析的基本原理
  8. 无人超市和传统超市的这些区别 你都知道吗?
  9. 判断是否为USD格式
  10. 第06课:生活中的中介模式——找房子问中介