0

0

MySQL分库分表的方式有哪些

WBOY

WBOY

发布时间:2023-06-02 12:34:14

|

3968人浏览过

|

来源于亿速云

转载

    一、为什么要分库分表

    如果一个网站业务快速发展,那这个网站流量也会增加,数据的压力也会随之而来,比如电商系统来说双十一大促对订单数据压力很大,tps十几万并发量,如果传统的架构(一主多从),主库容量肯定无法满足这么高的tps,业务越来越大,单表数据超出了数据库支持的容量,持久化磁盘io,传统的数据库性能瓶颈,产品经理业务·必须做,改变程序,数据库刀子切分优化。由于数据库连接数不足并且表中的数据量庞大,即使进行了优化,查询性能仍然较低,因此需要进行分割。

    二、什么是分库分表

    • 分库分表方案是对关系型数据库数据存储和访问机制的一种补充。

    • 分库:将一个库的数据拆分到多个相同的库中,访问的时候访问一个库

    • 分表:把一个表的数据放到多个表中,操作对应的某个表就行

    三、分库分表的几种方式

    MySQL分库分表的方式有哪些

    1.垂直拆分

    (1) 数据库垂直拆分

    MySQL分库分表的方式有哪些

    根据业务拆分,如图,电商系统,拆分成订单库,会员库,商品库

    (2)表垂直拆分

    MySQL分库分表的方式有哪些

    根据业务去拆分表,如图,把user表拆分成user_base表和user_info表,use_base负责存储登录,user_info负责存储基本用户信息

    垂直拆分特点:

    • 每个库(表)的结构都不一样

    • 每个库(表)的数据至少一列一样

    • 每个库(表)的并集是全量数据

    垂直拆分优缺点

    优点:

    • 拆分后业务清晰(专库专用按业务拆分)

    • 数据维护简单,按业务不同,业务放到不同机器上

    缺点:

    • 如果单表的数据量,写读压力大

    • 受某种业务决定,或者被限制,也就是说一个业务往往会影响到数据库的瓶颈(性能问题,如双十一抢购)

    • 部分业务无法关联join,只能通过java程序接口去调用,提高了开发复杂度

    2. 水平拆分

    (1) 数据库水平拆分

    MySQL分库分表的方式有哪些

    如图,按会员库拆分,拆分成会员1库,会员2库,以userId拆分,userId尾号0-5为1库 6-9为2库,还有其他方式,进行取模,偶数放到1库,奇数放到2库

    (2) 表水平拆分

    MySQL分库分表的方式有哪些

    如图把users表拆分成users1表和users2表,以userId拆分,进行取模,偶数放到users1表,奇数放到users2表

    水平拆分的其他方式:

    • range来分,每个库一段连续的数据,这个一般是按比如时间范围来的,但是这种一般较少用,因为很容易产生热点问题,大量的流量都打在最新的数据上了,优点:扩容的时候,就很容易,因为你只要预备好,给每个月都准备一个库就可以了,到了一个新的月份的时候,自然而然,就会写新的库了 缺点:大部分的 请求,都是访问最新的数据。实际生产用range,要看场景,你的用户不是仅仅访问最新的数据,而是均匀的访问现在的数据以及历史的数据

    • hash分发,优点:可以平均分配每个库的数据量和请求压力 缺点:扩容起来比较麻烦,会有一个数据迁移的这么一个过程

      magento(麦进斗)
      magento(麦进斗)

      Magento是一套专业开源的PHP电子商务系统。Magento设计得非常灵活,具有模块化架构体系和丰富的功能。易于与第三方应用系统无缝集成。Magento开源网店系统的特点主要分以下几大类,网站管理促销和工具国际化支持SEO搜索引擎优化结账方式运输快递支付方式客户服务用户帐户目录管理目录浏览产品展示分析和报表Magento 1.6 主要包含以下新特性:•持久性购物 - 为不同的

      下载

    (3) 水平拆分特点

    • 每个库(表)的结构都一样

    • 每个库(表)的数据都不一样

    • 每个库(表)的并集是全量数据

    (4) 水平拆分优缺点

    优点:

    • 单库/单表的数据保持在一定量(减少),有助于性能提高

    • 提高了系统的稳定性和负载能力

    • 拆分表的结构相同,程序改造较少。

    缺点:

    • 数据的扩容很有难度维护量大

    • 拆分规则很难抽象出来

    • 分片事务的一致性问题部分业务无法关联join,只能通过java程序接口去调用

    四、分库分表带来的问题

    • 分布式事务

    • 跨库join查询

    • 分布式全局唯一id

    • 开发成本 对程序员要求高

    五、分库分表技术如何选型

    (1) 分库分表的开源框架

    • jdbc 直连层:shardingsphere、tddl

    • proxy 代理层:mycat,mysql-proxy(360)

    jdbc直连层

    MySQL分库分表的方式有哪些

    jdbc直连层又叫jdbc应用层,是因为所有分片规则,所有分片逻辑,包括处理分布式事务 所有这些问题它都是在应用层,所有项目都是由war包构成的,所有分片都写成了jar包,放到了war包里面,java需要虚拟机去运行的,虚拟机运行的时候就会把war包里面的字节文件进行classLoder加载到jvm内存中,所有分片逻辑都是基于内存方进行操作的

    (2) proxy代理层

    MySQL分库分表的方式有哪些

    如图,proxy代理层,所有分片规则,所有分片逻辑,包括处理分布式事务都在mycat写好了,所有分片逻辑都是基于mycat方进行操作

    (3) jdbc直连层和proxy代理层优缺点

    • jdbc直连层性能高,只支持java语言,支持跨数据库

    • proxy代理层开发成本低,支持跨语言,不支持跨数据库

    相关专题

    更多
    Java 桌面应用开发(JavaFX 实战)
    Java 桌面应用开发(JavaFX 实战)

    本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

    37

    2026.01.14

    php与html混编教程大全
    php与html混编教程大全

    本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

    19

    2026.01.13

    PHP 高性能
    PHP 高性能

    本专题整合了PHP高性能相关教程大全,阅读专题下面的文章了解更多详细内容。

    37

    2026.01.13

    MySQL数据库报错常见问题及解决方法大全
    MySQL数据库报错常见问题及解决方法大全

    本专题整合了MySQL数据库报错常见问题及解决方法,阅读专题下面的文章了解更多详细内容。

    19

    2026.01.13

    PHP 文件上传
    PHP 文件上传

    本专题整合了PHP实现文件上传相关教程,阅读专题下面的文章了解更多详细内容。

    16

    2026.01.13

    PHP缓存策略教程大全
    PHP缓存策略教程大全

    本专题整合了PHP缓存相关教程,阅读专题下面的文章了解更多详细内容。

    6

    2026.01.13

    jQuery 正则表达式相关教程
    jQuery 正则表达式相关教程

    本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

    3

    2026.01.13

    交互式图表和动态图表教程汇总
    交互式图表和动态图表教程汇总

    本专题整合了交互式图表和动态图表的相关内容,阅读专题下面的文章了解更多详细内容。

    45

    2026.01.13

    nginx配置文件详细教程
    nginx配置文件详细教程

    本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

    9

    2026.01.13

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    MySQL 教程
    MySQL 教程

    共48课时 | 1.7万人学习

    MySQL 初学入门(mosh老师)
    MySQL 初学入门(mosh老师)

    共3课时 | 0.3万人学习

    简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信

    共1课时 | 791人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号