MySQL分库分表

1.什么是分库分表

(1)垂直拆分

  • 垂直分库:以表为依据,根据业务将不同表拆分到不同库中。特点:在高并发下,提高磁盘IO和数据量连接数。

  • 垂直分表:以字段为依据,根据字段属性将不同字段拆分到不同表中。特点:冷热数据分离;减少IO过度争抢,两表互不影响。

(2)水平拆分

  • 水平分库:将一个库的数据拆分到多个库中。特点:解决了单库大数量,高并发的性能瓶颈问题;提高了系统的稳定性和可用性。

       路由规则:

  • 根据id节点取模
  • 按id也就是范围路由,节点1(1-100万 ),节点2(100万-200万)

  •  
  • 水平分表:将一个表的数据拆分到多个表中(可以在同一个库内)。特点:优化单一表数据量过大而产生的性能问题;避免IO争抢并减少锁表的几率。

2.什么场景下使用分库分表?

  • 高并发写入场景:当应用面临高并发的写入请求时,单一数据库可能无法满足写入压力,此时可以将数据按照一定规则拆分到多个数据库中,每个数据库处理部分数据的写入请求,从而提高写入性能。
  • 数据量巨大场景:随着数据量的不断增加,单一数据库的存储和查询性能可能逐渐下降。此时,可以将数据按照一定的规则拆分到多个表中,每个表存储部分数据,从而分散数据的存储压力,提高查询性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值