几句话数据库分库分表

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值