开发者社区> 技术小甜> 正文

MySQL5.7 开启GTID复制模式终于不用开启log_slave_updates参数了

简介:
+关注继续查看

MySQL5.6的GTID复制模式,必须开启log_slave_updates参数,否则启动就报错,因为需要在binlog找到同步复制的信息(UUID:事务号),如果在密集型写的环境,比如双十一大促在线支付,这无疑增加了从库不必要的磁盘IO开销。

wKiom1RrBTLyonpmAAF1WPY7xsY589.jpg

(注:开启log_slave_updates参数,是把relay-log里的日志内容再记录到slave本地的binlog里。)


但在MySQL5.7里,官方终于做了调整,用一张gtid_executed系统表记录同步复制的信息(UUID:事务号),这样就可以不用开启log_slave_updates参数,减少了从库的压力。

wKioL1RrDDuhFxJDAAKyEyfsYGI574.jpg


如果你玩过MariaDB10的话,可以看到这块MySQL5.7是参考了MariaDB10的GTID,但MySQL5.7还不能做到普通模式和GTID模式在线切换,如果你想切换为普通模式,必须在my.cnf里,同时在master和slave上注销掉以下参数:

1
2
gtid_mode = ON
enforce_gtid_consistency = 1

并且重启mysql进程才生效。在易用性上,MySQL5.7 GTID还是美中不足。


参考:

wKiom1RrD0uzM54bAAEkVpk-UFA809.jpg











本文转自hcymysql51CTO博客,原文链接:http://blog.51cto.com/hcymysql/1579197 ,如需转载请自行联系原作者
















版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
MySQL的binlog是默认开启的吗?具体如何使用?
MySQL的binlog是默认开启的吗?具体如何使用?
320 0
MySQL中binlog和relay log清理方式
1. MySQL server的binlog清理 1.1 使用MySQL参数控制 expire_logs_days 设置二进制日志的过期天数,过了指定天数的日志将被自动删除,可动态修改 如果设置了非0值,则在mysqld启动和日志刷新时,可能执行清理超过定义天数的binlog file 全局变...
4655 0
MySQL启用GTID的限制
开启 GTID 之后,会由部分的限制,内容如下: 更新非事务引擎表GTID 同步复制是基于事务的,所以 MyISAM 存储引擎不支持,这可能导致多个 GTID 分配给同一个事务。 使用GTID时,使用非事务性存储引擎(如MyISAM)对表的更新不能在与使用事务性存储引擎(如InnoDB)的表的更新相同的语句或事务中进行。
2589 0
MySQL中sync_relay_log选项对I/O thread的影响分析
MySQL中sync_relay_log选项对I/O thread的影响分析
3327 0
+关注
技术小甜
文章
问答
视频
文章排行榜
最热
最新
相关电子书
更多
MySQL Replication: Latest Developments
立即下载
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载