- 为什么分库分表
(1) Mysql提倡的表行数在百万量级,而实际我们经常遇到千万级和亿级数据的大表,使用分表可以提升查询效率。
(2) 在读写分离、一主多从的架构下,如果大量的写请求达到主库,当主库不堪重负时,使用分库缓解压力。 - 怎么拆分
(1) 垂直拆分
分库:按照业务线分,比如订单一个库,商品一个库,用户一个库。
分表:按照属性分,比如一个厂商表,可以按照属性拆分,比如分成基础信息表,结算信息表,服务信息表等等。
(2) 水平拆分
范围切分:Range[0,1000] [1001,2000] [2001,3000],这样做的缺点是无法处理集中请求的数据,集中请求的时候,很大概率还是会落在某一个库或者表上。
Hash切分:可以利用一致性hash算法,一致性hash推荐百度第一篇推荐的博客园,写的非常好。
时间切分:冷热数据分离,比如只保存近一年的数据,历史数据全部迁移到弹性库,保持数据库的健壮性,降低表数据的量级,提高数据库性能。
几句话数据库分库分表
最新推荐文章于 2022-11-29 11:44:20 发布