MySQL数据库分库分表介绍

为什么要分库分表?

当数据海量时,数据库的压力很大,会成为系统运行的瓶颈。

从数据库角度入手改造,那就涉及到分库分表。

什么是分库?

分库是将原来在一个数据库实例上的不同库,拆开,变成多个数据库实例。举例:

在一台服务器上,安装了MySQL,创建了三个数据库,分别是商品库、订单库、财务库。

这三个数据库,都运行在一台服务器的MySQL实例中。

分库就是将这三个数据库,拆开,放到三台服务器上,每台服务器都安装MySQL,只创建一个库。如下图:

Node就是指不同的服务器。

通过这种方式,可以缓解单台服务器的压力,把压力分摊到三台服务器。

什么是分表?

比如:数据库中的商品表,表数据量很大,有三千万条记录,查询很慢。

然后有三台服务器,三台服务器上都安装MySQL,都创建商品库,商品库中创建商品表。通过把商品表的三千万条记录拆成三份,每份一千万条记录。把三千万条数据平摊到这三台服务器上进行存储。

如上图所示,商品表1、商品表2、商品表3,每张表存储一千万条记录。

怎么实现分库分表?

问题来了,有了分库分表的想法,如何实现呢?

这就要借助分库分表中间件来完成。

目前常见的分库分表中间件有以下几种:

综合来看,目前比较活跃,还在更新维护,且开源,支持的数据库种类最多的中间件是shardingsphere。它是一款分布式 SQL 事务和查询引擎。

官方文档:

https://shardingsphere.apache.org/index_zh.html

相关推荐
P-ShineBeam20 小时前
智能体-LangChain框架-Tools工具的使用指南
数据库·人工智能·语言模型·自然语言处理·langchain
ziyue757520 小时前
python进行磁盘文件迁移,不影响软件使用
开发语言·数据库·python
八月瓜科技20 小时前
擎策·知海知识产权数据库迭代更新,专利检索&管理效率再提一倍!
数据库·人工智能·科技·深度学习·机器人
一条泥憨鱼21 小时前
苍穹外卖【day3|菜品管理】
java·数据库·sql·mysql·mybatis
andafaAPS21 小时前
安达发|金属加工企业如何靠生产计划排单软件打破产能困局?
数据库·aps生产排程·安达发aps·生产计划排单软件·计划排产软件
故渊at21 小时前
第二板块:Android 四大组件标准化学理 | 第十篇:ContentProvider 数据共享与 SQLite 引擎
android·jvm·数据库·sqlite·contentprovider
星光不负赶路人!21 小时前
【工作记录】sqlserver数据库操作及迁移
服务器·数据库·sqlserver
下班走回家21 小时前
向量数据库在 AI 应用中的角色:从 Milvus 到 Chroma
数据库·人工智能·milvus
TDengine (老段)21 小时前
TDengine SQL 解析与词法分析 — 从字符串到 AST 的转换之路
大数据·数据库·sql·物联网·时序数据库·tdengine·涛思数据
StarRocks_labs21 小时前
StarRocks × Iceberg:联邦查询实践解析
数据库·starrocks·sql·iceberg·物化视图