数据库分库分表的策略问题概述

前言

中大型项目中,一旦遇到数据量比较大,小伙伴应该都知道就应该对数据进行拆分了。有垂直和水平两种。

垂直拆分比较简单,也就是本来一个数据库,数据量大之后,从业务角度进行拆分多个库。如下图,独立的拆分出订单库 和 用户库

你知道怎么分库分表吗?如何做到永不迁移数据和避免热点吗?

水平拆分的概念,是同一个业务数据量大之后,进行水平拆分。

你知道怎么分库分表吗?如何做到永不迁移数据和避免热点吗?

上图中订单数据达到了4000万,我们也知道mysql单表存储量推荐是百万级,如果不进行处理,mysql单表数据太大,会导致性能变慢。使用方案可以参考数据进行水平拆分。把4000万数据拆分4张表或者更多。当然也可以分库,再分表;把压力从数据库层级分开。

数据量大时分表存储的策略:

  • 首先一个就是hash确定入那个表,但是这样会有一个扩容问题  ==>  hash取模方案
  • 另外一个就是确定范围的存储,但是这样其实某一时间段只会操作一张表,所以有个热点问题  ==>  range范围方案
  • 另外一个就是两种的结合,首先分组,就是在数据库上面增加一个分类,方便后面的扩容; 先根据id确定分组,之后对总的表数取模确定那个表,解决热点问题,每个数据库要根据自己的表数,确定属于自己的取模数; ==> 组合方案

参考的链接:

https://mp.weixin.qq.com/s/qhu9AbqYF7ZqVAmxlwbAxw

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值