mysql分库分表怎么实现_mysql水平分表方案

mysql分库分表怎么实现_mysql水平分表方案这个数值依据: 这个数值与MySQL 的配置以及机器的硬件有关。因为,MySQL 为了提高性能,会将表的索引装载到内存中。InnoDB buffer size 足够的情况下,其能完成全加载进内存,查询

mysql分库分表

mysql分库分表怎么实现_mysql水平分表方案

一、垂直拆分

1、垂直分库:在分布式系统开发中,基本都是按照模块划分,每个业务模块建立一个数据库

mysql分库分表怎么实现_mysql水平分表方案

 特点:业务区分度高,方便维护管理;各个模块独立维护,可以分摊系统的维护成本,提高可用性。

 2、垂直分表:单张宽表,根据实际业务场景,可以拆分为多个子表。

mysql分库分表怎么实现_mysql水平分表方案

垂直拆分的缺点:

1、阿里巴巴《Java 开发手册》提出单表行数超过 500 万行或者单表容量超过 2GB,会影响性能。

这个数值依据: 这个数值与MySQL 的配置以及机器的硬件有关。因为,MySQL 为了提高性能,会将表的索引装载到内存中。InnoDB buffer size 足够的情况下,其能完成全加载进内存,查询不会有问题。但是,当单表数据库到达某个量级的上限时,导致内存无法存储其索引,使得之后的 SQL 查询会产生磁盘 IO,从而导致性能下降。当然,这个还有具体的表结构的设计有关,最终导致的问题都是内存限制。这里,增加硬件配置,可能会带来立竿见影的性能提升哈。

2、根据模块分库(分布式事务问题):当系统之间交互操作数据库时无法完成事务问题,增加了开发的复杂度。

3、关联数据问题:如果需要一个综合数据,需要通过接口聚合各个模块的数据

二、水平拆分

水平拆分的核心:

  • 数据均衡分配
  • 数据查询尽可能在一张表,一个库中

1、水平分库

mysql分库分表怎么实现_mysql水平分表方案

特点:两个子库的数据结构完全一样 

优点:分库后,系统的可用性较高;每个库、每个表的数据量减少了,性能较高

2、水平分表

mysql分库分表怎么实现_mysql水平分表方案

 

特点:两个子表的数据结构完全一致。

优点:每个表中的数据量减少了,缓解数据操作的压力

水平拆分优点:

  • 分摊数据的存储、查询压力
  • 由于拆分后的数据结构与之前一样,所以对于应用层来说,不用做较大的改动

水平拆分缺点

  • 拆分规则如何制定
  • 数据的路由算法,如果后续加表、加库,是否需要重新处理老数据。

三、分库分表带来的问题

1、分布式ID,需要设计

2、分布式事务问题

3、跨库跨表查询问题:

JDBC连接层:sharding-jdb

proxy代理模式:mycat、mysql-proxy

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/6180.html

(0)
上一篇 2023-04-15
下一篇 2023-04-15

相关推荐

  • mysql处理高并发,防止库存超卖[亲测有效]

    mysql处理高并发,防止库存超卖[亲测有效]一般电子商务网站都会遇到如团购、秒杀、特价之类的活动,而这样的活动有一个共同的特点就是访问量激增、上千甚至上万人抢购一个商品。然而,作为活动商品,库存肯定是很有限的,如何控制库存不让出现超买,以防止…

    2023-03-05
    145
  • SQLPro Studio for Mac 2020.38 数据库管理器

    SQLPro Studio for Mac 2020.38 数据库管理器SQLPro Studio mac 是Mac上一款简单,强大的macOS 数据库管理器,使用sqlpro studio mac可以创建表格,自定义查询,自动完成和语法突出显示,同时可以执行多个查询,…

    2023-02-22
    145
  • mysql-调优[通俗易懂]

    mysql-调优[通俗易懂]mysql调优 1.选择合适的存储引擎 + 经常用来读的表使用myisam引擎 + 其余的表都使用innodb引擎 2.SQL语句调优(尽量避免全表扫描) + 在select where order

    2023-02-04
    145
  • Python中elif关键字的用法

    Python中elif关键字的用法Python是一种面向对象、解释型语言,它与其他语言不同的地方在于采用了indentation(缩进)代替了语句结束的分号或者大括号等符号。Python中的if/elif/else也是控制流程中比较重要的关键字,能够帮助程序员控制程序的逻辑,在不同的条件下执行不同的代码。

    2024-02-12
    82
  • 使用Python编写自定义Spin Widget控件

    使用Python编写自定义Spin Widget控件Spin Widget控件是一种可以让用户在一个特定范围内选择数值的控件,它可以用来替代文本输入框,可以减少用户输入错误的概率,提高用户交互的体验。Python的Qt库中提供了QSpinBox和QDoubleSpinBox两个控件实现了基本的Spin Widget功能,但是这两个控件还是有一定的局限性,因此我们可以进行自定义的Spin Widget控件编写。

    2024-03-22
    90
  • 如何将Python文件转换为可执行文件exe?

    如何将Python文件转换为可执行文件exe?Python是一种解释性语言,无需编译即可运行。但有时您可能需要将Python代码打包成可执行文件。将Python代码打包成可执行文件可以使代码更加便携,无需安装Python解释器也能运行。

    2024-06-22
    37
  • echarts绘制饼状图及属性设置 数据来自数据库[亲测有效]

    echarts绘制饼状图及属性设置 数据来自数据库[亲测有效] E charts 官网有很多样式可以选 https://echarts.apache.org/examples/zh/index.html#chart-type-pie 但是我发现 数据 都…

    2023-03-24
    141
  • Python数据类型:变量、数据类型及其应用

    Python数据类型:变量、数据类型及其应用a href=”https://www.python100.com/a/sm.html”font color=”red”免责声明/font/a a href=”https://beian.miit.gov.cn/”苏ICP备2023018380号-1/a Copyright www.python100.com .Some Rights Reserved.

    2023-12-20
    107

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注