数据结构 Synchnorized golang爬虫 分布式服务 mAPI pointers debugging concurrency sms java商城源码 进销存源码 ps字体旋转角度 ubuntu显示隐藏文件夹 mac版的matlab好用吗 idea格式化代码设置 oracle分析函数 python3正则表达式 python平方函数 python读取数据库 linuxshell volist 万能低格工具 ps怎么插入表格 超星网课助手 按键精灵脚本教程 subscribe 小度音箱app 黑客攻防技术宝典 c语言图书管理系统 羽化快捷键 dnf卡邮件 砸金蛋抽奖活动 华为mate8和p9哪个好 x怎么截图 filesaver qq三国辅助 pdf分割合并工具 上网监控系统 方正兰亭粗黑简体 小米6拆机
当前位置: 首页 > 学习教程  > 编程语言

myCat 中间件实现读写分离(不包括分片分库)

2020/11/24 9:48:37 文章标签: 测试文章如有侵权请发送至邮箱809451989@qq.com投诉后文章立即删除

开两台- 虚拟机 做Mysql 读写分离. 安装mysql服务,版本要一致 下载mycat 官网: http://www.mycat.io/ mycat 需要jdk 支持 -> 自己配置jdk环境,不解释。 mycat 安装 第一步:把MyCat的压缩包上传到linux服务器 第二步&…

  1. 开两台- 虚拟机 做Mysql 读写分离.

  2. 安装mysql服务,版本要一致

  3. 下载mycat
    官网: http://www.mycat.io/
    1.png

  4. mycat 需要jdk 支持 -> 自己配置jdk环境,不解释=。=

  5. mycat 安装
    第一步:把MyCat的压缩包上传到linux服务器
    第二步:解压缩,得到mycat目录
    第三步:进入mycat/bin,启动MyCat
    启动命令:./mycat start
    停止命令:./mycat stop
    重启命令:./mycat restart
    注意:可以使用mysql的客户端直接连接mycat服务。默认服务端口为8066

  6. mycat 文件简介
    6.1 schema.xml
    1、Schema:逻辑库,与MySQL中的Database(数据库)对应,一个逻辑库中定义了所包括的Table。
    2、Table:表,即物理数据库中存储的某一张表,与传统数据库不同,这里的表格需要声明其所存储的逻辑 数据节点DataNode。在此可以指定表的分片规则。
    3、DataNode:MyCAT的逻辑数据节点,是存放table的具体物理节点,也称之为分片节点,通过DataSource来关联到后端某个具体数据库上
    4、DataSource:定义某个物理库的访问地址,用于捆绑到Datanode上
    6.2 server.xml
    image.png
    用户账号密码权限配置=。=
    6.3 rule.xml
    image.png
    schema.xml -> 中 分表会用到,也就是 分表的规则,默认的也有,自定义也可以=。=

  7. 开始

<?xml version="1.0"?>
<!DOCTYPE mycat:schema SYSTEM "schema.dtd">
<mycat:schema xmlns:mycat="http://io.mycat/">

	<schema name="gcddDb" checkSQLschema="false" sqlMaxLimit="100" dataNode="dn1"></schema>
	<dataNode name="dn1" dataHost="M1" database="db1" />
	<dataHost name="M1" maxCon="1000" minCon="10" balance="1"
			  writeType="0" dbType="mysql" dbDriver="native" switchType="2"  slaveThreshold="100">
		<heartbeat>show slave status</heartbeat>
		<!-- can have multi write hosts -->
		<writeHost host="hostM1" url="192.168.1.148:3306" user="root"
				   password="123456">
			<readHost host="hostS" url="192.168.1.193:3306" user="root" password="00000000" />

		</writeHost>	
	</dataHost>
	
</mycat:schema>

(1)	设置 balance="1"与writeType="0"
Balance参数设置:
1. balance=“0”, 所有读操作都发送到当前可用的writeHost上。
2. balance=“1”,所有读操作都随机的发送到readHost。
3. balance=“2”,所有读操作都随机的在writeHost、readhost上分发
WriteType参数设置:
1. writeType=“0”, 所有写操作都发送到可用的writeHost上。
2. writeType=“1”,所有写操作都随机的发送到readHost。
3. writeType=“2”,所有写操作都随机的在writeHost、readhost分上发。
 “readHost是从属于writeHost的,即意味着它从那个writeHost获取同步数据,因此,当它所属的writeHost宕机了,则它也不会再参与到读写分离中来,即“不工作了”,这是因为此时,它的数据已经“不可靠”了。基于这个考虑,目前mycat 1.3和1.4版本中,若想支持MySQL一主一从的标准配置,并且在主节点宕机的情况下,从节点还能读取数据,则需要在Mycat里配置为两个writeHost并设置banlance=1。”
(2)	设置 switchType="2" 与slaveThreshold="100"
switchType 目前有三种选择:
-1:表示不自动切换
1 :默认值,自动切换
2 :基于MySQL主从同步的状态决定是否切换
“Mycat心跳检查语句配置为 show slave status ,dataHost 上定义两个新属性: switchType="2" 与slaveThreshold="100",此时意味着开启MySQL主从复制状态绑定的读写分离与切换机制。Mycat心跳机制通过检测 show slave status 中的 "Seconds_Behind_Master", "Slave_IO_Running", "Slave_SQL_Running" 三个字段来确定当前主从同步的状态以及Seconds_Behind_Master主从复制时延。“
  1. 配置数据库
    8.1 主数据库配置
[root@localhost ~]# vim /etc/my.cnf

image.png

在[mysqld]段下添加:
binlog-do-db=db1
binlog-ignore-db=mysql
#启用二进制日志
log-bin=mysql-bin
#服务器唯一ID,一般取IP最后一段
server-id=148
#然后保存退出,重启服务
wq
service mysqld restart
#然后连接数据库
[root@localhost ~]# mysql -uroot -p123456
mysql>GRANT FILE ON *.* TO 'backup'@'%' IDENTIFIED BY '123456';
mysql>GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* to 'backup'@'%' identified by '123456'; 
#刷新权限
mysql> FLUSH PRIVILEGES;
#查询master的状态
mysql> show master status;

image.png


8.2 从数据库配置

#修改my.conf文件
[mysqld]
server-id=193
#配置从服务器
mysql>change master to master_host='192.168.1.148',master_port=3306,master_user='backup',master_password='123456',master_log_file='mysql-bin.000002',master_log_pos=4219;
#注意语句中间不要断开,master_port为mysql服务器端口号(无引号),master_user为执行同步操作的数据库账户,“4219”无单引号(此处的4219就是show master status 中看到的position的值,这里的mysql-bin.000002就是file对应的值)
#启动从服务器复制功能
Mysql>start slave; 
#检查从服务器复制功能状态:
mysql> show slave status

image.png
注:Slave_IO及Slave_SQL进程必须正常运行,即YES状态,否则都是错误的状态(如:其中一个NO均属错误)。


错误处理:
如果出现此错误:
Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work.
因为是mysql是克隆的系统所以mysql的uuid是一样的,所以需要修改。
解决方法:
删除/var/lib/mysql/auto.cnf文件,重新启动服务。


以上操作过程,从服务器配置完成。

可以mycat 测试,注意mycat 默认端口是 8066
账号密码在 server.xml 中配置
如果有错误 ,查看 log 文件分析解决~
有疑问 可以留言~~=。=


本文链接: http://www.dtmao.cc/news_show_400141.shtml

附件下载

相关教程

    暂无相关的数据...

共有条评论 网友评论

验证码: 看不清楚?