架构设计(二)之读写分离

1.读写分离

在 MySQL 主从同步架构中,传统的只有“主”数据库才提供读写操作服务,“从”数据库只作为备用。
读写分离则是把“读”操作分离出去,由“从”数据库承担读操作服务,主数据库提供写操作服务。

2.读写分离的作用

在主数据库中,如果读操作比较多,势必会影响写操作的吞吐量,给数据库带来性能瓶颈,读写分离就是为了提升读写的性能,充分利用主、从数据库的资源。

3.读写分离解决方案
  1. 应用程序自己做负载均衡,程序自己选择该读那个数据库,可以通过 spring 动态数据源或者 Mybaits Plus 拦截的方式配置insert、update、delete 操作走主库,而 select 操作走从库。
  2. 放在代理层做,比如:MySQL-Proxy,应用程序的连接都是透明的。
4.读写分离常用的中间件
  1. MySQL Proxy(官方推荐)
  2. MyCat
  3. Sharding JDBC
  4. TDDL
  5. Atlas
5.读写分离可能出现的问题

读写分离最大的问题是,主从同步如果发成延迟,从数据库的数据就是脏数据,就会造成数据一致性的问题。

5.读写分离保证数据一致性

一般的主从同步都是秒级的,单页可能出现延迟导致的数据一致性的问题。
所以,强一致性的业务,或者出现从数据库如果查不到的情况,可以选择性强制读取主库,这样最简单的方案,当然也可以通过其他第三方中间件完成。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值