使用gdb 修改mysql参数不重启:
mysql>show variables like 'log_slave%';
+-------------------+-------+
| Variable_name | Value |
+-------------------+-------+
| log_slave_updates |OFF |
+-------------------+-------+
mysql> set global log_slave_updates=on;
ERROR 1238 (HY000): Variable 'log_slave_updates' is a read only variable
# gdb -p $(pidof mysqld) -ex "set opt_log_slave_updates=1" -batch
mysql>show variables like 'log_slave%';
+-------------------+-------+
| Variable_name | Value |
+-------------------+-------+
| log_slave_updates | ON |
+-------------------+-------+
global log_slave_updates参数:
MySQL主从结构实际中是用到最多的一种架构。 新上的两台服务器B和C,要替换掉之前旧的服务器A,同时,B和C是新的主从关系。因此,配置成级联复制,来迁移数据,也方便切换。
架构图如下:
master A ------> slave B ------> slave C
有这么情况发生了,服务器B可以正常复制服务器A的数据,服务器B和C主从状态Slave_IO_Running和Slave_SQL_Running都是yes的,但是服务器C却无法复制新的数据。
原因分析:
1. 检查服务器B有没有开启二进制日志log_bin
2. log_slave_updates是否启用
log_slave_updates是将从服务器从主服务器收到的更新记入到从服务器自己的二进制日志文件中。
上面的问题是由于没有启用log_slave_updates = 1导致的。
总结:
因此,对于mysql级联复制,上游的从服务器不仅仅要开启log_bin还要开启log_slave_updates,否则将导致下游的从服务器无法更新复制。
阅读(2445) | 评论(0) | 转发(0) |