1.什么是分库分表
(1)垂直拆分:
- 垂直分库:以表为依据,根据业务将不同表拆分到不同库中。特点:在高并发下,提高磁盘IO和数据量连接数。
- 垂直分表:以字段为依据,根据字段属性将不同字段拆分到不同表中。特点:冷热数据分离;减少IO过度争抢,两表互不影响。
(2)水平拆分:
- 水平分库:将一个库的数据拆分到多个库中。特点:解决了单库大数量,高并发的性能瓶颈问题;提高了系统的稳定性和可用性。
路由规则:
- 根据id节点取模
- 按id也就是范围路由,节点1(1-100万 ),节点2(100万-200万)
- …
- 水平分表:将一个表的数据拆分到多个表中(可以在同一个库内)。特点:优化单一表数据量过大而产生的性能问题;避免IO争抢并减少锁表的几率。
2.什么场景下使用分库分表?
- 高并发写入场景:当应用面临高并发的写入请求时,单一数据库可能无法满足写入压力,此时可以将数据按照一定规则拆分到多个数据库中,每个数据库处理部分数据的写入请求,从而提高写入性能。
- 数据量巨大场景:随着数据量的不断增加,单一数据库的存储和查询性能可能逐渐下降。此时,可以将数据按照一定的规则拆分到多个表中,每个表存储部分数据,从而分散数据的存储压力,提高查询性能。