Mycat故障转移中writetype与switchtype,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

1.配置文件如下:

负载均衡类型,目前的取值有3种:

1.writeType="0",所有写操作发送到配置的第一个writeHost,第一个挂了切到还生存的第二个writeHost,重新启动后已切换后的为准,切换记录在配置文件中:dnindex.properties.

2.writeType="1",所有写操作都随机的发送到配置的writeHost。

3.writeType="2",没实现。



switchtype属性如下(控制自动切换的)


2 模拟数据库down机

2.1 主库down机

[root@localhost ~]# /etc/init.d/mysql stop
Shutting down MySQL.... [确定]


2.2 mycat插入数据

mysql> insert into zs values (2),(3);
Query OK, 2 rows affected (0.00 sec)
Records: 2 Duplicates: 0 Warnings: 0


2.3 查看备库

mysql> select * from zs;
+------+
| id |
+------+
| 1 |
| 2 |
| 3 |
+------+
3 rows in set (0.00 sec)
数据发送至备库,可见已切换成功


2.4 主库恢复

[root@localhost ~]# /etc/init.d/mysql start
Starting MySQL. [确定]

2.5 再次插入数据,并查看从和主

mycat> insert into zs values (4),(5);


从上:mysql> select * from zs;
+------+
| id |
+------+
| 1 |
| 2 |
| 3 |
| 4 |
| 5 |
+------+

主上:mysql> select * from zs;
+------+
| id |
+------+
| 1 |
+------+
1 row in set (0.00 sec)

通过上面的步骤可以发现,主库down掉后 就以从库为准了,就算主库恢复了,还是以从库为准,所以搭个双主是最好的解决办法

可以看下切换的记录文件

[root@localhost conf]# more dnindex.properties
#update
#Fri Apr 21 13:40:09 CST 2017
localhost3=0
localhost2=0
localhost1=1 ###使用第二个writehost

将新的主库down机 再恢复,又切换回原主库了

[root@localhost conf]# more dnindex.properties
#update
#Fri Apr 21 13:56:09 CST 2017
localhost3=0
localhost2=0
localhost1=0 ###使用第一个writehost
#这0和1代表的就是写入时使用第几个writehost的意思了

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。