Mysql 如何在 MGR 中使用非 Innodb 存储引擎

MGR插件默认不允许使用除Innodb之外的存储引擎进行组复制。文章提到,尝试在建表时更改存储引擎会导致错误,且官方建议关闭其他引擎。为解决此问题,文章提供了两种修改MGR源码的方法:直接将判断条件设为false或文明地添加自定义引擎到判断逻辑中,后者需要更多工作量。
摘要由CSDN通过智能技术生成
MGR 插件只允许 Innodb 作为组复制的存储引擎

如果想将自己的存储引擎用作 MGR 的引擎,在建表时加上 engine=my_db_engine 后缀,是会报错的
且在配置 MGR 时,官方文档也要求关闭了mysql 中的其它引擎
请添加图片描述

修改源码解决此问题

如果你有能力编码存储引擎,那么也有能力对 mysql 的源码进行改动并编译安装
只需要修改 MGR 插件源码中的两个位置即可
plugin/group_replication/src/observer_trans.cc:143
plugin/group_replication/src/asynchronous_channels_state_observer.cc:202
在这里插入图片描述
暴力的改法是将判断条件直接改成 false,亲测可行。
文明的改法是将自己的引擎加入判断条件中,我懒得这样改。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值