当前位置: 首页 > news >正文

MySQL 分库分表

分表

分表

将表按照某种规则拆分成多个表。

分表的使用原因

当数据量超大的时候,B-Tree索引效果很变差。

垂直分区

切分原则:把不常用或存储内容比较多的字段分到新的表中可使表存储更多数据。

原因,Innodb主索引叶子节点存储着当前行的所有信息,所以减少字段可使内存加载更多行数据。

水平分区

切分原则: 增量区间或散列或其他业务逻辑。

使用哪种切分方法要根据实际业务逻辑判断。

范围分区:

比如对表的访问多是近期产生的新数据,历史数据访问较少,可以考虑根据时间增量把数据按照一定时间段(比如每年)切分。

Hash分区:

如果对表的访问较均匀,没有明显的热点区域,则可以考虑用范围(比如每500w一个表)或普通Hash或一致性Hash来切分。

分区表

是什么

分区表是一个独立的逻辑表,但是底层由多个物理子表实现。

为什么

当数据量超大的时候,B-Tree索引就无法起作用了。

MySQL帮我们实现了传统分表后的SQL中间件。

对于原表分区后,对于应用层来说可以不做变化。

分区方式

哈希分区:使用哈希函数将数据均匀分布到不同的分区。

按范围分区:按照时间,地点分区等。

分区的使用场景

对数据的操作只涉及一部分数据,而不是所有数据 

为什么使用了分表

当数据量超大的时候,B-Tree索引就无法有效作用时候。

垂直分表切分原则

把不经常用的字段或者内容多个字段储存到另外一个表,因为InnoDB储存引擎的机制可以储存更多的数据。

水平分表切分原则

表访问的很均匀的话可以使用hash分区,行均匀的分到多表中。

表访问不均匀的话比如查看近期的数据多的话,可以使用按照范围分区。

分库

分库

将数据库的表分到多个数据库中。

分库使用原因

当单台数据库性能不满足需求时,数据库磁盘IO瓶颈和网络IO瓶颈。

分库的原则 

根据业务紧密程度拆分,因为跨数据库无法联表查询。

http://www.lryc.cn/news/401084.html

相关文章:

  • AutoMQ 社区双周精选第十二期(2024.06.29~2024.07.12)
  • Web开发:<div>标签作用
  • 如何使用unittest框架来编写和运行单元测试
  • 2024最新超详细SpringMvc常用注解总结
  • Linux硬件中断(IRQ)的基础知识
  • DP讨论——适配器模式
  • window下tqdm进度条
  • 记录些Redis题集(1)
  • 防火墙双机热备带宽管理综合实验
  • 【Redis】哨兵(sentinel)
  • 2024年高职云计算实验室建设及云计算实训平台整体解决方案
  • 入门实战篇,利用PADS Layout画电阻电容电感的封装
  • 解决npm install 安装报错记录贴
  • CollectionUtils的使用
  • WEB前端03-CSS3基础
  • 【java深入学习第7章】用 Spring Boot 和 Java Mail 轻松实现邮件发送功能
  • Linux抽象套接字
  • GA-Kmeans-Transformer-GRU时序聚类+状态识别组合模型,创新发文无忧!
  • Python面试全攻略:基础知识、特性、算法与实战解析
  • Linux网络编程-socket套接字使用详解
  • Leetcode 236. 二叉树的最近公共祖先
  • GPT-4从0到1搭建一个Agent简介
  • docker镜像源配置
  • 解读InnoDB数据库索引页与数据行的紧密关联
  • 以数据编织,重构数据管理新范式
  • 在linux x86服务器安装jdk
  • 2024智慧竞技游戏俱乐部线下面临倒闭?
  • jmeter分布式(四)
  • 如何解决手机游戏因IP代理被封禁无法正常游戏的问题?
  • windows10 安装Anaconda