1.读写分离
在 MySQL 主从同步架构中,传统的只有“主”数据库才提供读写操作服务,“从”数据库只作为备用。
读写分离则是把“读”操作分离出去,由“从”数据库承担读操作服务,主数据库提供写操作服务。
2.读写分离的作用
在主数据库中,如果读操作比较多,势必会影响写操作的吞吐量,给数据库带来性能瓶颈,读写分离就是为了提升读写的性能,充分利用主、从数据库的资源。
3.读写分离解决方案
- 应用程序自己做负载均衡,程序自己选择该读那个数据库,可以通过 spring 动态数据源或者 Mybaits Plus 拦截的方式配置insert、update、delete 操作走主库,而 select 操作走从库。
- 放在代理层做,比如:MySQL-Proxy,应用程序的连接都是透明的。
4.读写分离常用的中间件
- MySQL Proxy(官方推荐)
- MyCat
- Sharding JDBC
- TDDL
- Atlas
5.读写分离可能出现的问题
读写分离最大的问题是,主从同步如果发成延迟,从数据库的数据就是脏数据,就会造成数据一致性的问题。
5.读写分离保证数据一致性
一般的主从同步都是秒级的,单页可能出现延迟导致的数据一致性的问题。
所以,强一致性的业务,或者出现从数据库如果查不到的情况,可以选择性强制读取主库,这样最简单的方案,当然也可以通过其他第三方中间件完成。