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机
2.1 主库down机
-
[root@localhost ~]# /etc/init.d/mysql stop
Shutting down MySQL…. [确定]
-
2.2 mycat插入数据
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 查看备库
2.3 查看备库
-
mysql> select * from zs;
+——+
| id |
+——+
| 1 |
| 2 |
| 3 |
+——+
3 rows in set (0.00 sec)
数据发送至备库,可见已切换成功
-
2.4 主库恢复
2.4 主库恢复
-
[root@localhost ~]# /etc/init.d/mysql start
Starting MySQL. [确定]
-
2.5 再次插入数据,并查看从和主
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的意思了
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注亿速云行业资讯频道,感谢您对亿速云的支持。
原创文章,作者:carmelaweatherly,如若转载,请注明出处:https://blog.ytso.com/204348.html