MySQL8集群之MGR的重要参数使用及说明

来源:这里教程网 时间:2026-02-12 11:18:07 作者:
环境说明重要参数总结

记录一下MySQL8.0.x 官方推荐集群方案MGR,相关的重要参数设置

环境说明

版本 MySQL 8.0.27一主两从3台服务器做的MGR集群主要设置 my.cnf中的参数Linux 系统环境

重要参数

MySQL8的全部参数的官方说明文档地址:

https://dev.mysql.com/doc/refman/8.0/en/server-system-variable-reference.html

在安装MySQL,配置MGR集群之前,

请务必重点注意:所有服务器的 hostname 确保不一样 ,如果修改主机名称使用类似如下命令:

sudo hostnamectl set-hostname NEWHOSTNAMEHERE

另外记得修改 /etc/hosts 文件中的内容,将本次所有的主机名称配置对应IP地址,特别注意第1、2两行127.0.0.1的对应关系

127.0.0.1 localhost 127.0.1.1 mgr-node1 192.168.30.222 mgr-master mgr-master 192.168.30.247 mgr-node1 mgr-node1 192.168.30.248 mgr-node2 mgr-node2

下面列举MGR集群主要关注的几个参数,

参数名称默认数值建议说明server-id1唯一服务ID,务必确保每一台服务器不一样port3306客户端 和 服务端口 这两个可以不一样,建议所有服务器上端口一样admin_port33062管理接口,独立管理通道 防止客户端无法登录 ,通常还需要配置 admin_address 来指定监听的 IP 地址mysqlx-port33060用于 X 协议(MySQL X Protocol)所使用的 TCP 端口。X 协议是 MySQL 8.0 (以及 5.7.12+) 引入的一种新的、现代化的客户端-服务器通信协议,旨在提供更丰富的功能和更好的性能,特别是在与 MySQL Shell、NoSQL 式访问 和 文档存储 功能结合使用时disabled_storage_engines空需要禁止使用的存储引擎,MGR环境下禁止使用这种存储,一般可设置 MyISAM,BLACKHOLE,FEDERATED,ARCHIVE,MEMORYtransaction_isolationREPEATABLE-READ事务提交模式,建议使用 READ-COMMITTEDgtid_modeOFFMGR 强制依赖 GTID 进行事务跟踪 必须设置 ONlog_bin & log_slave_updatesOFFMGR 的基础 必须设置为 ONbinlog_formatROWMGR 依赖行格式 必须设置为 ROWtransaction_write_set_extractionXXHASH64MGR 用它来识别事务中修改的行(写入集),用于冲突检测和应用,通常设置为 XXHASH64。必须在所有成员上保持一致innodb_flush_log_at_trx_commit1控制事务提交时 redo log 如何写入磁盘,强烈建议设置为 1,这保证了事务的 ACID 特性(完全持久化)sync_binlog1控制 binlog 刷新到磁盘的频率,设置为 1 可确保每个事务提交后 binlog 都被同步到磁盘group_replication_transaction_size_limit150MB限制MGR中可以接受的事务大小上限,超过此大小的事务将被拒绝max_allowed_packet64MB定义服务器能够接收的最大网络包大小,建议小于上面参数值replica_pending_jobs_size_max128MB复制线程可以排队的最大事务大小innodb_log_file_size512MBInnoDB重做日志文件大小,通常设置为512MB-1GB之间group_replication_group_name空【必填】复制组的唯一标识符。在同一个MySQL集群中的所有节点都必须使用相同的组名group_replication_start_on_boot空【必填】表示MySQL服务器启动时,Group Replication会自动启动并尝试加入复制组group_replication_bootstrap_group空【必填】 这个参数通常在初始化复制组的第一个节点时设置为ON,表示该节点将启动一个新的复制组。一旦组已经启动,其他节点加入时都应将其设置为OFFgroup_replication_local_address空【必填】当前MySQL实例用于Group Replication通信的本地地址和端口group_replication_group_seeds空【必填】 复制组中至少一个或多个已知成员的地址列表。当一个新节点启动或尝试重新加入组时,它会使用这些地址来发现并连接到复制组的其他成员。这是一个引导列表,不要求列出所有成员group_replication_ip_allowlist空【必填】 定义了允许连接到Group Replication组的IP地址或IP地址范围。这有助于增强安全性,只允许来自指定网络的成员加入组,例如:“127.0.0.1,192.168.30.0/24”report_host空重要: 用于告知MySQL服务器在将信息报告给监控工具,对应performance_schema.replication_group_members 表中MEMBER_HOST的值,如果不配置,则默认取当前主机的hostname作为该字段值

除了以上列出的参数值,一般时间,时区等各节点都需要保证一致性。

另外最重要的是:

你的应用程序中的事务要尽可能的小

例如 DELETE UPDATE 范围数据的时候,需要优化完善之前的程序保证每一次范围尽可能的小!

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

相关推荐

热文推荐