这篇文章主要介绍了如何利用mycat实现mysql数据库读写分离,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

什么是MyCAT
- 一个彻底开源的,面向企业应用开发的大数据库集群 
- 支持事务、ACID、可以替代MySQL的加强版数据库 
- 一个可以视为MySQL集群的企业级数据库,用来替代昂贵的Oracle集群 
- 一个融合内存缓存技术、NoSQL技术、HDFS大数据的新型SQL Server 
- 结合传统数据库和新型分布式数据仓库的新一代企业级数据库产品 
- 一个新颖的数据库中间件产品 
MyCAT关键特性
- 支持SQL92标准 
- 支持MySQL、Oracle、DB2、SQL Server、PostgreSQL等DB的常见SQL语法 
- 遵守MySQL原生协议,跨语言,跨平台,跨数据库的通用中间件代理。 
- 基于心跳的自动故障切换,支持读写分离,支持MySQL主从,以及galera cluster集群。 
- 支持Galera for MySQL集群,Percona Cluster或者MariaDB cluster 
- 基于Nio实现,有效管理线程,解决高并发问题。 
- 支持数据的多片自动路由与聚合,支持sum,count,max等常用的聚合函数,支持跨库分页。 
- 支持单库内部任意join,支持跨库2表join,甚至基于caltlet的多表join。 
- 支持通过全局表,ER关系的分片策略,实现了高效的多表join查询。 
- 支持多租户方案。 
- 支持分布式事务(弱xa)。 
- 支持XA分布式事务(1.6.5)。 
- 支持全局序列号,解决分布式下的主键生成问题。 
- 分片规则丰富,插件化开发,易于扩展。 
- 强大的web,命令行监控。 
- 支持前端作为MySQL通用代理,后端JDBC方式支持Oracle、DB2、SQL Server 、 mongodb 、巨杉。 
- 支持密码加密 
- 支持服务降级 
- 支持IP白名单 
- 支持SQL黑名单、SQL注入攻击拦截 
- 支持prepare预编译指令 
- 支持非堆内存(Direct Memory)聚合计算 
- 支持PostgreSQL的native协议 
- 支持MySQL和oracle存储过程,out参数、多结果集返回 
- 支持zookeeper协调主从切换、zk序列、配置zk化 
- 支持库内分表 
- 集群基于ZooKeeper管理,在线升级,扩容,智能优化,大数据处理(2.0开发版)。 
1、这里是在mysql主从复制实现的基础上,利用mycat做读写分离,架构图如下:

2、Demo
2.1 在mysql master上创建数据库创建db1
2.2 在数据库db1创建表student

同时,因为配置好了mysql主从复制,在mysql slave上也有一样数据库和表
2.3 编辑 mycat的配置文件server.xml
test TESTDB user TESTDB true 
2.4编辑mycat的配置文件schema.xml
select user() 
到这里,利用mycat做读写分离就已经配置完了
注意 dataHost节点的下面三个属性
balance, switchType, writeType
balance="0", 不开启读写分离机制,所有读操作都发送到当前可用的writeHost上。
balance="1",全部的readHost与stand by writeHost参与select语句的负载均衡,简单的说,当双主双从模式(M1->S1,M2->S2,并且M1与M2互为主备),正常情况下,M2,S1,S2都参与select语句的负载均衡。
balance="2",所有读操作都随机的在writeHost、readhost上分发。
balance="3",所有读请求随机的分发到writeHost下的readhost执行,writeHost不负担读压力
writeType表示写模式
writeType="0",所有的操作发送到配置的第一个writehost
writeType="1",随机发送到配置的所有writehost
writeType="2",不执行写操作
switchType指的是切换的模式,目前的取值也有4种:
switchType=‘-1‘ 表示不自动切换
switchType=‘1‘ 默认值,表示自动切换
switchType=‘2‘ 基于MySQL主从同步的状态决定是否切换,心跳语句为show slave status
switchType=‘3‘基于MySQL galary cluster的切换机制(适合集群)(1.4.1),心跳语句为show status like ‘wsrep%‘。
感谢你能够认真阅读完这篇文章,希望小编分享的“如何利用mycat实现mysql数据库读写分离”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!
当前标题:如何利用mycat实现mysql数据库读写分离-创新互联
网址分享:http://www.cqwzjz.cn/article/dccodd.html

 建站
建站
 咨询
咨询 售后
售后
 建站咨询
建站咨询 
 