在MySQL主从架构集群中,如果主库发生故障,需要立刻提升一个从库为新主库。在这个过程中,有一个操作是在从库上执行stop slave停止复制的操作,一般情况下,会非常顺利。
但也有特殊情况下,会遇到stop slave被卡住的问题。
这样,给故障恢复过程造成了一定的困扰。
本文模拟一种stop slave被卡住的情况。
MySQL版本: 5.7.27-log
1.模拟过程
首先准备一个主从集群,具体过程参见MySQL主从集群搭建。
1.1.主库数据准备
mysql> create database app;
Query OK, 1 row affected (0.01 sec)
mysql>
CREATE TABLE `test` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`service_group_name` varchar(100) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
1.2 从库加读锁
首先保证从库复制正常,start slave已开启复制。
在从库上打开终端1,对数据表test加读锁:
mysql> lock tables app.test read;
Query OK, 0 rows affected (0.00 sec)
mysql>
1.3 主库写入数据
在主库上写入一条数据&#x