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