前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mycat读写分离原理_mycat主从复制

mycat读写分离原理_mycat主从复制

作者头像
全栈程序员站长
发布2022-11-04 10:03:40
4150
发布2022-11-04 10:03:40
举报
文章被收录于专栏:全栈程序员必看

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到教程 首先搭建mysql主从环境,及mycat安装 配置mycat的schema.xml文件

代码语言:javascript
复制
<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">
<schema name="hbk" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1"></schema>
<dataNode name="dn1" dataHost="host1" database="hbk" />
<dataHost name="host1" maxCon="1000" minCon="10" balance="0"
writeType="0" dbType="mysql" dbDriver="native" switchType="1"  slaveThreshold="100">
<heartbeat>select user()</heartbeat>
<writeHost host="hostM1" url="192.168.37.101:3306" user="root"
password="123456">
<readHost host="hostS2" url="192.168.37.100:3306" user="root" password="123456" />
</writeHost>
</dataHost>
</mycat:schema>

server.xml

代码语言:javascript
复制
<user name="mycat">
<property name="password">123456</property>
<property name="schemas">hbk</property>
</user>

mycat所在机器,配置hosts文件

在这里插入图片描述
在这里插入图片描述

启动mycat 测试结果: 当从节点宕机,主节点正常时,mycat能正常查询,和写入数据库。 当主节点宕机,从节点正常时,mycat读取和写入都失败。

在这里插入图片描述
在这里插入图片描述

因为我们的schema.xml的blance设置的为0,即不开启读写分离机制。 我们把blance设置为1,重启mycat,重新测试,结论如下: 依然查询报错,网上的结论是能查询,但是不能写入,为啥会报这个错误,怎么解决???

代码语言:javascript
复制
mysql> select * from student;
ERROR 1184 (HY000): Invalid DataSource:0

我查看了下日志,有报错信息:

在这里插入图片描述
在这里插入图片描述

文档参考 balance和 switchType。其中,balance指的负载均衡类型,目前的取值有4种:

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”,所有读请求随机的分发到wiriterHost对应的readhost执行,writerHost不负担读压力。 switchType指的是切换的模式,目前的取值也有4种: switchType=’-1’ 表示不自动切换; switchType=‘1’ 默认值,表示自动切换; switchType=‘2’ 基于MySQL主从同步的状态决定是否切换,心跳语句为 show slave status; switchType=’3’基于MySQL galary cluster的切换机制(适合集群)(1.4.1),心跳语句为 show status like ‘wsrep%’。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/182294.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月13日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档