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,亲测可行。
文明的改法是将自己的引擎加入判断条件中,我懒得这样改。