Mycat实现读写分离,主备热切换
实验环境:ubutu server 14
Master IP:172.16.34.212
Slave IP:172.16.34.34.156
Mycat server IP:172.16.34.219
不涉及过多理论,只有实现的过程。mysql读写分离和主备热切换,容灾,数据分片的实现手段目前比较流行的是Mycat。当然利用应用层代码去解决这些问题也是可以的。
1,首先到Github下载Mycat 1.6 版本的安装包,下载地址为:https://github.com/MyCATApache/Mycat-download
2,下载后解压到Mycat服务器某个目录
3,在主从复制的基础上去实现读写分离,主从复制可参考: http://www.cnblogs.com/NingKangMing/p/6110071.html
4,修改server.xml文件(此文件为Mycat的核心主配置文件,如user标签用于控制对外的可访问的用户及用户可访问的数据,是否只读等),我们配置一个euht用户,可访问数据库(schema.xml配置的逻辑数据库)为mycatdb,密码为123456,sql解析器为druidparser。默认端口8066。对外开放的用户名和密码为mycatuser,123456
<system>
<property name="defaultSqlParser">druidparser</property>
</system>
<user name="mycatuser">
<property name="password">123456</property>
<property name="schemas">mycatdb</property>
<property name="readOnly">false</property>
</user>
5,修改schema.xml文件,(schema.xml用于配置MyCat的读写分离、水平垂直折分集群,逻辑库、表、分片规则、DataNode以及DataSource),参考配置如下
<schema name="mycatdb" checkSQLschema="false" dataNode="datanoode1"/>
<dataNode name="datanoode1" dataHost="virtualHost" database="euhtnms" />
<dataHost name="virtualHost" maxCon="50" minCon="5" balance="3"
writeType="0" dbType="mysql" dbDriver="native" switchType="1" >
<heartbeat>select 1</heartbeat>
<writeHost host="whost1" url="172.16.34.212:3306" user="euht" password="123456">
<readHost host="rhost1" url="172.16.34.156:3306" user="euht" password="123456" />
</writeHost>
</dataHost>
配置说明:
Schema标签:name指明schema逻辑数据库的名称,checkSQLschema是否去除sql语句中的数据库名称,如果sql查询语句没有limit语句,sqlMaxLimit为查询语句加上limit。
dataNode标签:定义节点,指定数据虚拟服务器,数据库等属性
dataHost标签:定义具体的数据库实例,读写分离配置,心跳包语句。maxCon属性指定每个读写实例连接池的最大连接。minCon属性指定每个读写实例连接池的最小连接。balance属性,目前的取值有 4 种。
balance="0", 不开启读写分离机制,所有读操作都发送到当前可用的writeHost 上。
balance="1",所有读操作都随机的发送到readHost
balance="2",所有读操作都随机的在 writeHost、 readhost 上分发。
balance="3", 所有读请求随机分发到 wiriterHost 对应的 readhost 执行
writeType属性,负载均衡类型,目前的取值有3种:
1. writeType=”0”, 所有写操作都发送到可用的writeHost上。
2. writeType=”1”,所有写操作都随机的发送到readHost。
3. writeType=”2”,所有写操作都随机的在writeHost、readhost分上发。
switchType 属性:
-1 表示不自动切换
1 默认值,自动切换
2 基于MySQL 主从同步的状态决定是否切换
writeHost,readHost,heartBeat标签,定义真实服务器的读写Host,heartBeat为心跳包语句。以上定义了一主一从的读写分离机制,writeHost下可以有多个readHost。
6,测试读写分离
进入bin目录启动mycat (确保配置的读写分离Host已经配置了主从数据同步)
Sudo ./mycat start
查看Mycat是否正常启动(查看logs的wrapper.log)
Mycat已经成功启动,下面测试读写分离的效果
连接上Mycat(根据server.xml配置的用户名和密码,我配置的是mycatuser,123456,Mycat运行默认端口为8066)
已经成功连接到Mycat,并发现有一个mycatdb的虚拟数据库,其背后有主从两台服务器。
我们在主从复制未关闭的情况下插入一条数据到euhtnms的testtb看能否成功。
Show tables;发现背后的数据库表,这说明我们的mycat已经成功的和主备数据库中的数据库连接上了。先在有主从复制的情况下插入一条数据,再选出来看看。
到其背后的两台服务器看数据是否正常
主数据库的数据正常通过mycat代理层插入了。
从服务器的数据通过主从复制同步过来了。
查看读写分离是否成功,先测试是否读一定是从我们配置的156服务器读,我们可以先到156停掉主从复制(stop slave)。然后再从mycat代理端插入数据
我们看到,刚插入的数据没被select 出来。这是因为我们把主从复制关掉了。代理层只是把数据写到主服务器212.从服务没进行数据同步,此时再读,由于读服务器是156,所以只能查出以前的数据。此时再把slave打开,可以从代理层看到所有数据了。当读服务器宕机变得不可用将会用主服务器去读,反之一样。(打开slave后从代理端读的效果如下)
如果配置有双主结构,log_slave_updates 这个选项需要设置到myssql的my.cnf配置文件中
到此mycat的读写分离已经完成,当然这不是一个高可用的架构。要做到高性能,高可用,需要考虑很多因素.............有待更新。
Mycat实现读写分离,主备热切换的更多相关文章
- Mycat在MySQL主从模式(1主1从)下读写分离和及自动切换模式的验证
实验环境 两台Centos7 MySQL5.7.12 IP地址为:192.168.10.36 192.168.10.37 一台Centos7 Mycat IP地址为:192.168.10.31 一 ...
- mycat(读写分离、负载均衡、主从切换)
博主本人平和谦逊,热爱学习,读者阅读过程中发现错误的地方,请帮忙指出,感激不尽 1.环境准备 1.1新增两台虚拟机 mycat01:192.168.247.81 mycat02:192.168.247 ...
- Mycat分布式数据库架构解决方案--Mycat实现读写分离
echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 安装完 ...
- SpringBoot 整合 MyCat 实现读写分离
MyCat一个彻底开源的,面向企业应用开发的大数据库集群.基于阿里开源的Cobar产品而研发.能满足数据库数据大量存储:提高了查询性能.文章介绍如何实现MyCat连接MySQL实现主从分离,并集成Sp ...
- Redis主备自动切换
Sentinel(哨兵)是用于监控redis集群中Master状态的工具. 一.Sentinel作用 1.Master状态检测 2.如果Master异常,则会进行Master-Slave切换,将 ...
- 物理DG主备库切换时遇到ORA-16139: media recovery required错误
在物理DG主备库切换时遇到ORA-16139: media recovery required错误 SQL> ALTER DATABASE COMMIT TO SWITCHOVER TO PRI ...
- 云计算之路-阿里云上:RDS数据库连接数过万引发故障,主备库切换后恢复正常
非常抱歉!今天 12:03-12:52 ,由于数据库连接数异常突增超过1万,达到了阿里云RDS的最大连接数限制,影响了全站的正常访问.由此给您带来麻烦,请您谅解. 在发现数据库连接数突增的问题后,我们 ...
- GoldenGate 传统抽取进程随 DataGuard 主备快速切换的方案(ADG 模式)
环境描述: 1.节点描述 节点 IP 节点描述 11.6.76.221 GG 抽取端 / DG 节点,数据库版本号为 Oracle-11.2.0.3,与 11.6.76.222 组成 DataGuar ...
- Mycat的读写分离
1. Mycat实现读写分离的部署: https://www.cnblogs.com/softidea/p/5447566.html springboot动态数据源的原理以及配置: Spring内置了 ...
随机推荐
- Genymotion无法下载OVA文件
百度 下载Genymotion离线OVA文件(http://pan.baidu.com/s/1jIe5pjC ) 将OVA离线文件放到这个目录下:C:\Users\Administrator\AppD ...
- maven url
aliyun阿里云Maven仓库地址--加速你的maven构建 maven仓库用过的人都知道,国内有多么的悲催.还好有比较好用的镜像可以使用,尽快记录下来.速度提升100倍. http://mav ...
- DDD开发框架ABP之本地化/多语言支持
本地化(Localization)也就是多语言功能,借此用户能够选择他的母语或熟悉的语言来使用系统,这显然非常有利于软件系统推向国际化.一个应用程序的UI界面至少有一种语言,DDD开发框架ABP就提供 ...
- 【转】PHP调试开发工具你认识多少?
来源:PHP100中文网(http://www.php100.com/html/itnews/PHPxinwen/2009/0902/3257.html) PHP现在已经是使用最为广泛的开源服务器端脚 ...
- 为jQuery-easyui的tab组件添加右键菜单功能
加入了右击TAB选项卡时显示关闭的上下文菜单 具体实现代码: 右键菜单 HTML: <div id="mm" class="easyui-menu" st ...
- 带给你灵感:30个超棒的 SVG 动画展示【上篇】
前端开发人员和设计师一般使用 CSS 来创建 HTML 元素动画.然而,由于 HTML 在创建图案,形状,和其他方面的局限性,它们自然的转向了 SVG,它提供了更多更有趣的能力.借助SVG,我们有更多 ...
- Quill – 可以灵活自定义的开源的富文本编辑器
Quill 的建立是为了解决现有的所见即所得(WYSIWYG)的编辑器本身就是所见即所得(指不能再扩张)的问题.如果编辑器不正是你想要的方式,这是很难或不可能对其进行自定义以满足您的需求. Quill ...
- scroll事件实现监控滚动条并分页显示示例(zepto.js)
scroll事件实现监控滚动条并分页显示示例(zepto.js ) 需求:在APP落地页上的底部位置显示此前其他用户的购买记录,要求此div盒子只显示3条半,但一页有10条,div内的滑动条滑到一页 ...
- HTML基础知识总结
经过这段时间的学习,对于html的一些基础知识有了一定的了解.所谓好记性不如烂笔头,唯有一点点累积,才能汇聚成知识的海洋.现在,我对这段时间的学习做一个总结. 一.HTML的定义 HTML,超文本标记 ...
- ZedGraph饼图---傻瓜版
GraphPane pGraphPane=this.zedGraphControl1.GraphPane;//调用饼图类 pGraphPane.Title.Text = "重金属含量分析图& ...