Mycat实现读写分离

Mycat是一个开源的数据库中间件,用于实现读写分离。通过配置,Mycat可以在主从数据库之间进行智能切换,确保读操作在从库执行,写操作在主库执行。本文介绍了Mycat的高可用架构,详细讲解了如何配置和启动Mycat以实现读写分离,包括schema.xml和server.xml的配置,并提供了测试验证步骤。
摘要由CSDN通过智能技术生成

原理

  • Mycat是什么?是一个开源的数据库中间件,在阿里Cobar基础上进行二次开发的,介于数据库与应用之间,进行数据处理与交互的中间件服务,可以简单的理解成数据库代理。
  • 如上为Mycat的高可用架构图,通过keepalived搭建多个Mycat集群,其中writeHost表示主节点,readHost表示从节点,Mycat内部定期对一个dataHost里所有的writeHost与readHost节点发起心跳检测,正常情况下,Mycat会将第一个writeHost作为写节点,所有的DML SQL会发送给此节点,若Mycat开启了读写分离,则Select SQL会根据读写分离策略发往readHost(+writeHost)执行。当一个dataHost里面配置了多个writeHost时,如果第一个writeHost宕机,则Mycat会在默认的3次心跳检查失败后,自动切换到下一个可用的writeHost,以此类推。
  • 传统的从代码层面实现读写分离(实现方式:注解+aop),需要配置主从两个数据源,和在代码层面明确指定用哪个数据源,增大了代码量,并且耦合在代码中不利于拓展与后续维护,一旦进行修改就需要重新编译打包。而采用数据库中间件,我们的应用只需要与数据库中间件交互,而无需关注复杂的数据库部署。

实现

1.下载Mycat安装包:

   官网下载地址:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值