Chinaunix首页 | 论坛 | 博客
  • 博客访问: 342114
  • 博文数量: 87
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 727
  • 用 户 组: 普通用户
  • 注册时间: 2014-11-27 15:56
个人简介

开心了, 就笑;不开心了,就过会儿再笑。。。。

文章分类

全部博文(87)

文章存档

2017年(16)

2016年(28)

2015年(33)

2014年(10)

我的朋友

分类: Mysql/postgreSQL

2017-10-09 16:00:05

使用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) |
给主人留下些什么吧!~~