如果需要了解Mycat可以参考以下链接:
Mysql - 分库分表_naki_bb的博客-CSDN博客
|
主机
|
角色
|
用户名
|
密码
|
|
192.168.200.211
|
master
|
root
|
1234
|
|
192.168.200.212
|
slave
|
root
|
1234
|
主从的搭建可以参考:
Mysql - 主从复制_naki_bb的博客-CSDN博客
- <schema name="ITCAST_RW" checkSQLschema="true" sqlMaxLimit="100" dataNode="dn7"> schema>
-
- <dataNode name="dn7" dataHost="dhost7" database="itcast" />
-
- <dataHost name="dhost7" maxCon="1000" minCon="10" balance="1" writeType="0" dbType="mysql" dbDriver="jdbc" switchType="1" slaveThreshold="100">
- <heartbeat>select user()heartbeat>
- <writeHost host="master1" url="jdbc:mysql://192.168.200.211:3306?useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf8" user="root" password="1234" >
- <readHost host="slave1" url="jdbc:mysql://192.168.200.212:3306?useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf8" user="root" password="1234" />
- writeHost>
- dataHost>

|
参数
值
|
含义
|
|
0
|
不开启读写分离机制
,
所有读操作都发送到当前可用的
writeHost
上
|
| 1 |
全部的
readHost
与 备用的
writeHost
都参与
select
语句的负载均衡(主要针对于双主双从模式)
|
| 2 |
所有的读写操作都随机在
writeHost , readHost
上分发
|
| 3 |
所有的读请求随机分发到
writeHost
对应的
readHost
上执行
, writeHost
不负担读压力
|
- <user name="root" defaultAccount="true">
- <property name="password">123456property>
- <property name="schemas">ITCAST_RWproperty>
-
-
- user>
测试
配置完毕MyCat后,重新启动MyCat。
- bin/mycat stop
- bin/mycat start
我们需要准备5台服务器,具体的服务器及软件安装情况如下:
| 编号 | IP | 预装软件 | 角色 |
| 1 |
192.168.200.210
|
MyCat
|
MyCat
中间件服务器
|
| 2 |
192.168.200.211
| mysql | Master1 |
| 3 |
192.168.200.212
| mysql | Slaver1 |
| 4 |
192.168.200.213
| mysql | Master2 |
| 5 |
192.168.200.214
| mysql | Slaver2 |
- 关闭以上所有服务器的防火墙:
- systemctl stop firewalld
- systemctl disable firewalld

A. 修改配置文件 /etc/my.cnf
- #mysql 服务ID,保证整个集群环境中唯一,取值范围:1 – 2^32-1,默认为1
- server-id=1
- #指定同步的数据库
- binlog-do-db=db01
- binlog-do-db=db02
- binlog-do-db=db03
- # 在作为从数据库的时候,有写入操作也要更新二进制日志文件
- log-slave-updates
systemctl restart mysqld
- #创建itcast用户,并设置密码,该用户可在任意主机连接该MySQL服务
- CREATE USER 'itcast'@'%' IDENTIFIED WITH mysql_native_password BY 'Root@123456';
- #为 'itcast'@'%' 用户分配主从复制权限
- GRANT REPLICATION SLAVE ON *.* TO 'itcast'@'%';
show master status ;

2). Master2(192.168.200.213)

A. 修改配置文件 /etc/my.cnf
- #mysql 服务ID,保证整个集群环境中唯一,取值范围:1 – 2^32-1,默认为1
- server-id=3
- #指定同步的数据库
- binlog-do-db=db01
- binlog-do-db=db02
- binlog-do-db=db03
- # 在作为从数据库的时候,有写入操作也要更新二进制日志文件
- log-slave-updates
systemctl restart mysqld
- #创建itcast用户,并设置密码,该用户可在任意主机连接该MySQL服务
- CREATE USER 'itcast'@'%' IDENTIFIED WITH mysql_native_password BY 'Root@123456';
- #为 'itcast'@'%' 用户分配主从复制权限
- GRANT REPLICATION SLAVE ON *.* TO 'itcast'@'%';
show master status ;

A. 修改配置文件 /etc/my.cnf
- #mysql 服务ID,保证整个集群环境中唯一,取值范围:1 – 2^32-1,默认为1
- server-id=2
systemctl restart mysqld
A. 修改配置文件 /etc/my.cnf
- #mysql 服务ID,保证整个集群环境中唯一,取值范围:1 – 2^32-1,默认为1
- server-id=4
systemctl restart mysqld
需要注意slave1对应的是master1,slave2对应的是master2。
A. 在 slave1(192.168.200.212)上执行
CHANGE MASTER TO MASTER_HOST='192.168.200.211', MASTER_USER='itcast', MASTER_PASSWORD='Root@123456', MASTER_LOG_FILE='binlog.000002', MASTER_LOG_POS=663;
CHANGE MASTER TO MASTER_HOST='192.168.200.213', MASTER_USER='itcast', MASTER_PASSWORD='Root@123456', MASTER_LOG_FILE='binlog.000002', MASTER_LOG_POS=663;
- start slave;
- show slave status \G;

2). 两台主库相互复制

Master2 复制 Master1,Master1 复制 Master2。
CHANGE MASTER TO MASTER_HOST='192.168.200.213', MASTER_USER='itcast', MASTER_PASSWORD='Root@123456', MASTER_LOG_FILE='binlog.000002', MASTER_LOG_POS=663;
CHANGE MASTER TO MASTER_HOST='192.168.200.211', MASTER_USER='itcast', MASTER_PASSWORD='Root@123456', MASTER_LOG_FILE='binlog.000002', MASTER_LOG_POS=663;
- start slave;
- show slave status \G;

经过上述的三步配置之后,双主双从的复制结构就已经搭建完成了。 接下来,我们可以来测试验证一下。
测试
<schema name="ITCAST_RW2" checkSQLschema="true" sqlMaxLimit="100" dataNode="dn7"> schema>
<dataNode name="dn7" dataHost="dhost7" database="db01" />
- <dataHost name="dhost7" maxCon="1000" minCon="10" balance="1" writeType="0" dbType="mysql" dbDriver="jdbc" switchType="1" slaveThreshold="100">
- <heartbeat>select user()heartbeat>
- <writeHost host="master1" url="jdbc:mysql://192.168.200.211:3306?useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf8" user="root" password="1234" >
- <readHost host="slave1" url="jdbc:mysql://192.168.200.212:3306?useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf8" user="root" password="1234" />
- writeHost>
- <writeHost host="master2" url="jdbc:mysql://192.168.200.213:3306?useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf8" user="root" password="1234" >
- <readHost host="slave2" url="jdbc:mysql://192.168.200.214:3306?useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf8" user="root" password="1234" />
- writeHost>
- dataHost>

属性说明:
- <user name="root" defaultAccount="true">
- <property name="password">123456property>
- <property name="schemas">SHOPPING,ITCAST,ITCAST_RW2property>
-
-
- user>
测试:
登录MyCat,测试查询及更新操作,判定是否能够进行读写分离,以及读写分离的策略是否正确。当主库挂掉一个之后,是否能够自动切换。