前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL在线开启 GTID

MySQL在线开启 GTID

作者头像
MySQL技术
发布2022-11-22 15:03:05
3.1K0
发布2022-11-22 15:03:05
举报
文章被收录于专栏:MySQL技术MySQL技术

前言:

GTID 是 MySQL 5.6 的新特性,可简化 MySQL 的主从切换以及 Failover。但是当我们开启 binlog 时,MySQL 并没有默认开启 GTID ,好在 GTID 可以在线开启,本篇文章我们一起来看下如何在线开启 GTID ,如果你的数据库实例原来未启用 GTID ,可以参考本篇文章来开启 GTID 。

1. GTID 参数介绍

GTID 相关的参数,我们一般会关注 gtid_mode 和 enforce_gtid_consistency 这两个。

gtid_mode 参数控制是否启用基于 GTID 的日志记录以及日志可以包含的事务类型。该参数默认为 OFF ,有以下四个有效值:

  • OFF:表示生成的是匿名事务,从库只能应用匿名事务。
  • OFF_PERMISSIVE:新产生的事务都是匿名事务,但也允许有 GTID 事务被复制同步。
  • ON_PERMISSIVE:新产生的都是 GTID 事务,但也允许有匿名事务被复制同步。
  • ON:新生成的是 GTID 事务,从库只能应用 GTID 事务。

该参数无法跳跃修改,一次修改只能改成原相邻值。例如,如果 gtid_mode 当前设置为 OFF_PERMISSIVE,则可以更改为 OFF 或 ON_PERMISSIVE,但不能更改为 ON。

enforce_gtid_consistency 参数决定是否允许事务违反 GTID 一致性。此参数默认为 OFF ,在启用基于 GTID 的复制之前,必须将此变量设置为 ON。该参数有以下三个有效值:

  • OFF:允许所有事务违反 GTID 一致性。
  • ON:不允许任何事务违反 GTID 一致性。
  • WARN:表示允许事务违反 GTID 一致性,但会将警告信息记录到 ERROR LOG。
2. 在线开启 GTID 步骤

我们以 MySQL 5.7.23 社区版为例,演示下如何在线开启 GTID 。未更改前,请确保你的环境已开启 binlog 二进制日志,且 gtid_mode = OFF 。

第一步:检查数据库中是否有不支持 GTID 的操作。主从实例均执行:

SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = WARN;

观察一段时间,确认错误日志无警告信息,若无告警信息则执行第二步

第二步:设置 ENFORCE_GTID_CONSISTENCY 为 ON 。主从实例均执行:

SET @@GLOBAL.ENFORCE_GTID_CONSISTENCY = ON;

第三步:设置GTID_MODE = OFF_PERMISSIVE,主从实例均执行:

SET @@GLOBAL.GTID_MODE = OFF_PERMISSIVE;

哪个服务器首先执行此语句并不重要,但是所有服务器必须在任何服务器开始下一步之前完成此步骤。

第四步:设置GTID_MODE = ON_PERMISSIVE 主从实例均执行:

SET @@GLOBAL.GTID_MODE = ON_PERMISSIVE;

第五步:确保在线的匿名事务数为 0 ,设置 GTID_MODE=ON,主从实例均执行:

SHOW STATUS LIKE 'ONGOING_ANONYMOUS_TRANSACTION_COUNT';

SET @@GLOBAL.GTID_MODE = ON;

第六步:从库执行重启,设置为 GTID 模式。仅在从库实例执行:

STOP SLAVE;

CHANGE MASTER TO MASTER_AUTO_POSITION = 1;

START SLAVE;

第七步:将 GTID 参数添加到配置文件 [mysqld] 部分,主从实例均需要。

gtid_mode = ON

enforce_gtid_consistency = ON

总结:

经过以上步骤,我们已完成在线开启 GTID ,整体过程还是比较平滑的,一定要注意按顺序修改,若有主从库,则需要在主从库上都修改完才能进行下一步骤,如果你只是单实例的话,则只需要在此实例上修改即可。还要注意的一点是开启 GTID 后,会不允许违反 GTID 一致性的 SQL 执行,例如 CREATE TABLE AS SELECT 语法在 GTID 模式下不支持。

参考:

  • https://www.modb.pro/db/427795
  • https://dev.mysql.com/doc/refman/5.7/en/replication-mode-change-online-enable-gtids.html

- End -

动动手指转发、在看

是对我最大的鼓励

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-09-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 MySQL技术 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. GTID 参数介绍
  • 2. 在线开启 GTID 步骤
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档