怎么做数据库扩展(scale out)

常用方式

把负载(数据)做一个划分,让其不断细分下去,划分不跟数据库相关,跟应用相关

常见的拆分方式

  • 按照业务划分:把不同地域的用户的请求和数据放在不同的数据库中
    • 优点: 不需要用数据库本身的内核
  • 分库/分表的扩展模式
    • Middleware:把请求分拆给多个数据库,然后再合起来

    • 问题:

      • 负载不均
      • 有些业务很难拆分(很难交给不同的数据库实现交互)
        • 订酒店:把不同的酒店分到不同的数据库
        • 转账:更新两个用户的账户,需要两个用户的账户都需要在一个数据库上,因为有事务的功能呀;不好拆,可以通过在middlewares上进行处理
      • 未必能拆分的好,对一些需求无法通过拆分来实现。
    • 拆分数据库可能带有的问题:

    • 查询分解:

      • 需要对它进行分析,以及用一种好的方式去分割数据。但并不是所有情况都可以

并行/分布式数据库

  • 最初以nosql形式出现。
  • 一个数据库分摊到多个计算机,对于应用而言,这就是一个数据库,不需要关心,如何拆分。
架构设计
  • Shared everything:进程可以访问和存储其他

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值