MySQL:互联网公司常用分库分表方案汇总!

本文介绍了水平分表(按字段和业务拆分)、垂直分库(按业务模块拆分)的概念、场景和优化原理,以及分库分表工具如ShardingSphere和TDDL。此外,还讨论了在微服务架构中如何处理非partitionkey查询和扩容问题,以及与SpringCloud阿里巴巴等相关技术的结合。
摘要由CSDN通过智能技术生成

2、水平分表

**概念:**以字段为依据,按照一定策略(hash、range等),将一个表中的数据拆分到多个表中。 结果:

  • 每个表的结构都一样;
  • 每个表的数据都不一样,没有交集;
  • 所有表的并集是全量数据;

**场景:**系统绝对并发量并没有上来,只是单表的数据量太多,影响了SQL效率,加重了CPU负担,以至于成为瓶颈。推荐:一次SQL查询优化原理分析**分析:**表的数据量少了,单次SQL执行效率高,自然减轻了CPU的负担。

3、垂直分库

**概念:**以表为依据,按照业务归属不同,将不同的表拆分到不同的库中。结果:

  • 每个库的结构都不一样;
  • 每个库的数据也不一样,没有交集;
  • 所有库的并集是全量数据;

**场景:**系统绝对并发量上来了,并且可以抽象出单独的业务模块。**分析:**到这一步,基本上就可以服务化了。例如ÿ

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值