使用基于 GTID 的复制
以下内容说明了如何在 Amazon RDS for MySQL 数据库实例间使用采用二进制日志(binlog)复制的全局事务标识符(GTID)。
如果您使用的是二进制日志复制,不熟悉 MySQL 的基于 GTID 的复制,请参阅 MySQL 文档中的 Replication with global transaction identifiers
所有 RDS for MySQL 5.7 版本、RDS for MySQL 版本 8.0.26 及更高的 MySQL 8.0 版本均支持基于 GTID 的复制。复制配置中的所有 MySQL 数据库实例必须满足该要求。
主题
全局事务标识符 (GTID) 概述
全局事务标识符 (GTID) 是为提交的 MySQL 事务生成的唯一标识符。您可以使用 GTID 让二进制日志复制的故障排除更加简单便捷。
MySQL 使用两种不同类型的事务进行二进制日志复制:
-
GTID 事务 – 由 GTID 标识的事务。
-
匿名事务 – 未分配 GTID 的事务。
在复制配置中,GTID 在所有数据库实例中是唯一的。GTID 简化了复制配置,因为在使用它们时,您不必引用日志文件位置。通过使用 GTID,还可以更轻松地跟踪复制的事务并确定源实例和副本是否一致。
您可以使用基于 GTID 的复制,通过 RDS for MySQL 只读副本复制数据。您可以在创建新的只读副本时配置基于 GTID 的复制,也可以转换现有的只读副本以使用基于 GTID 的复制。
您还可以在与 RDS for MySQL 之间的延迟复制配置中使用基于 GTID 的复制。有关更多信息,请参阅 使用 MySQL 配置延迟复制。
基于 GTID 的复制的参数
可以使用以下参数配置基于 GTID 的复制。
参数 | 有效值 | 描述 |
---|---|---|
|
|
|
|
|
|
注意
在 AWS Management Console中,gtid_mode
参数显示为 gtid-mode
。
对于基于 GTID 的复制,请为数据库实例或只读副本的参数组使用这些设置:
-
ON
和ON_PERMISSIVE
仅适用于从 RDS 数据库实例的传出复制。这两个值都可以让 RDS 数据库实例为复制的事务使用 GTID。ON
要求目标数据库也使用基于 GTID 的复制。ON_PERMISSIVE
让基于 GTID 的复制成为目标数据库上的可选项。 -
OFF_PERMISSIVE
(如果设置)表明您的 RDS 数据库实例可以接受来自源数据库的传入复制。无论源数据库是否使用基于 GTID 的复制,它们都可以这样做。 -
OFF
(如果设置)表明您的 RDS 数据库实例只接受来自不使用基于 GTID 的复制的源数据库的传入复制。
有关参数组的更多信息,请参阅 Amazon RDS 的参数组。
为新的只读副本配置基于 GTID 的复制
在为 RDS for MySQL 数据库实例启用基于 GTID 的复制时,将自动为数据库实例的只读副本配置基于 GTID 的复制。
为新的只读副本启用基于 GTID 的复制
-
确保与数据库实例关联的参数组具有以下参数设置:
-
gtid_mode
–ON
或ON_PERMISSIVE
-
enforce_gtid_consistency
–ON
有关使用参数组设置配置参数的更多信息,请参阅 Amazon RDS 的参数组。
-
-
如果更改了数据库实例的参数组,请重新引导数据库实例。有关执行该操作的更多信息,请参阅重启中的数据库实例。
-
创建数据库实例的一个或多个只读副本。有关执行该操作的更多信息,请参阅创建只读副本。
Amazon RDS 尝试使用 MASTER_AUTO_POSITION
在 MySQL 数据库实例和只读副本之间配置基于 GTID 的复制。如果尝试失败,Amazon RDS 将使用日志文件位置与只读副本之间进行复制。有关 MASTER_AUTO_POSITION
的更多信息,请参阅 MySQL 文档中的 GTID 自动定位
为现有的只读副本配置基于 GTID 的复制
对于具有不使用基于 GTID 的复制的只读副本的现有 MySQL 数据库实例,您可以在数据库实例和只读副本之间配置基于 GTID 的复制。
为现有的只读副本启用基于 GTID 的复制
-
如果数据库实例或任何只读副本使用了低于 8.0.26 的 RDS for MySQL 8.0.x 版本,请将数据库实例或只读副本升级为 8.0.26 或更高的 MySQL 8.0 版本。所有 RDS for MySQL 5.7 均支持基于 GTID 的复制。
有关更多信息,请参阅 升级 MySQL 数据库引擎。
-
(可选)重置 GTID 参数并测试数据库实例和只读副本的行为:
-
确保与数据库实例和每个只读副本关联的参数组将
enforce_gtid_consistency
参数设置为WARN
。有关使用参数组设置配置参数的更多信息,请参阅 Amazon RDS 的参数组。
-
如果更改了数据库实例的参数组,请重新引导数据库实例。如果更改了只读副本的参数组,请重新引导只读副本。
有关更多信息,请参阅“重启中的数据库实例”。
-
运行具有正常工作负载的数据库实例和只读副本并监控日志文件。
如果看到有关与 GTID 不兼容的事务的警告,请调整您的应用程序,以使其仅使用与 GTID 兼容的功能。在继续执行下一步之前,请确保数据库实例未生成有关与 GTID 不兼容的事务的任何警告。
-
-
为允许匿名事务的基于 GTID 的复制重置 GTID 参数,直到只读副本已处理所有这些事务。
-
确保与数据库实例和每个只读副本关联的参数组具有以下参数设置:
-
gtid_mode
–ON_PERMISSIVE
-
enforce_gtid_consistency
–ON
-
-
如果更改了数据库实例的参数组,请重新引导数据库实例。如果更改了只读副本的参数组,请重新引导只读副本。
-
-
等待复制所有匿名事务。要检查是否复制了这些事务,请执行以下操作:
-
在源数据库实例上运行以下语句。
SHOW MASTER STATUS;
记下
File
和Position
列中的值。 -
在每个只读副本上,使用上一步中的源实例上的文件和位置信息运行以下查询。
SELECT MASTER_POS_WAIT('
file
',position
);例如,如果文件名是
mysql-bin-changelog.000031
并且位置是107
,请运行以下语句。SELECT MASTER_POS_WAIT('mysql-bin-changelog.000031', 107);
如果只读副本超过指定的位置,查询将立即返回。否则,该函数将等待一段时间。在查询返回所有只读副本的结果时,请继续执行下一步。
-
-
仅重置基于 GTID 的复制的 GTID 参数。
-
确保与数据库实例和每个只读副本关联的参数组具有以下参数设置:
-
gtid_mode
–ON
-
enforce_gtid_consistency
–ON
-
-
重新引导数据库实例和每个只读副本。
-
-
在每个只读副本上,运行以下过程。
CALL mysql.rds_set_master_auto_position(1);
为具有只读副本的 MySQL 数据库实例禁用基于 GTID 的复制
您可以为 一个具有只读副本的 MySQL 数据库实例。
为 具有只读副本的 MySQL 数据库实例禁用基于 GTID 的复制
-
在每个只读副本上,运行以下过程:
CALL mysql.rds_set_master_auto_position(0);
-
将
gtid_mode
重置为ON_PERMISSIVE
。-
确保与 MySQL 数据库实例和每个只读副本关联的参数组将
gtid_mode
设置为ON_PERMISSIVE
。有关使用参数组设置配置参数的更多信息,请参阅 Amazon RDS 的参数组。
-
重新引导 MySQL 数据库实例和每个只读副本。有关重新引导的更多信息,请参阅重启中的数据库实例。
-
-
将
gtid_mode
重置为OFF_PERMISSIVE
。-
确保与 MySQL 数据库实例和每个只读副本关联的参数组将
gtid_mode
设置为OFF_PERMISSIVE
。 -
重新引导 MySQL 数据库实例和每个只读副本。
-
-
等待在所有只读副本上应用所有 GTID 事务。要检查是否应用了这些事务,请按以下步骤操作:
-
在 MySQL 数据库 实例上,运行
SHOW MASTER STATUS
命令。您的输出应类似于以下输出。
File Position ------------------------------------ mysql-bin-changelog.000031 107 ------------------------------------
记下输出中的文件和位置。
-
在每个只读副本上,使用上一步中的源实例上的文件和位置信息运行以下查询:
对于 MySQL 8.0.26 及更高的 MySQL 8.0 版本
SELECT SOURCE_POS_WAIT('
file
',position
);对于 MySQL 5.7 版本
SELECT MASTER_POS_WAIT('
file
',position
);例如,如果文件名是
mysql-bin-changelog.000031
并且位置是107
,请运行以下语句:对于 MySQL 8.0.26 及更高的 MySQL 8.0 版本
SELECT SOURCE_POS_WAIT('mysql-bin-changelog.000031', 107);
对于 MySQL 5.7 版本
SELECT MASTER_POS_WAIT('mysql-bin-changelog.000031', 107);
-
-
重置 GTID 参数以禁用基于 GTID 的复制。
-
确保与 MySQL 数据库实例和每个只读副本关联的参数组具有以下参数设置:
-
gtid_mode
–OFF
-
enforce_gtid_consistency
–OFF
-
-
重新引导 MySQL 数据库实例和每个只读副本。
-