『叶问』#41,三节点的MGR集群,有两个节点宕机后还能正常工作吗

Posted 老叶茶馆_

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了『叶问』#41,三节点的MGR集群,有两个节点宕机后还能正常工作吗相关的知识,希望对你有一定的参考价值。

每周学点MGR知识

内容节选自GreatSQL MGR FAQ文档,更多内容请访问 https://gitee.com/GreatSQL/GreatSQL-Doc/blob/master/docs/GreatSQL-FAQ.md ,该链接会保持更新

1. 三节点的MGR集群,有两个节点宕机后还能正常工作吗

要看具体是哪种情况。

如果两个节点是正常关闭的话,则会向MGR集群发送退出信号,这种情况下,这两个节点属于正常退出,最后仅剩的节点会被提升为Primary角色,还可以正常工作,允许对其进行读写,只是此时没有可用性冗余了。当其他节点再次启动并加入集群后,又能恢复正常服务。

如果是因为网络故障,或者mysqld进程发生oom、或被误杀、或其他原因退出了,则这些节点会被标识为 UNREACHABLE 状态,等待直到 group_replication_member_expel_timeout 时长(单位:秒)后这个节点才会正式退出集群。在这种情况下,一旦超过多数派节点处于 UNREACHABLE 状态时,则整个集群不可用,无法提供读写服务。这种情况下,需要把剩下的节点重启MGR服务才能恢复。

正常情况下,不要把 group_replication_member_expel_timeout 值调整太大,并且MGR的事务一致性级别尽量不要选择 AFTER 模式,以防出现整个集群服务不可用的问题,详细参见这篇文章:为什么MGR一致性模式不推荐AFTER

2. MGR可以像主从复制那样只启动两个节点吗

MGR在初始化启动时,是可以只启动两个节点,甚至只有一个节点,但是这样就失去MGR的意义了。因为只要少于三个节点,就没办法进行多数派投票,当发生网络故障等情况时,无法投票确认哪些节点该被踢出集群。


《实战MGR》视频课程

戳此小程序即可直达B站

或复制链接在浏览器中打开

  • https://space.bilibili.com/1363850082


文章推荐:


点击文末“阅读原文”直达「叶问」专栏

以上是关于『叶问』#41,三节点的MGR集群,有两个节点宕机后还能正常工作吗的主要内容,如果未能解决你的问题,请参考以下文章

《叶问》38期,MGR整个集群挂掉后,如何才能自动选主,不用手动干预

『叶问』#39,都有哪些情况可能导致MGR服务无法启动

03.安装部署MGR集群 | 深入浅出MGR

PXC集群三节点异常宕机全部挂掉如何寻找引导节点

mysql-MGR高可用集群

3. 安装部署MGR集群 | 深入浅出MGR