分布式集群中网络分区问题


前言

网络分区就是其中的一种故障类型。

通常情况下,网络分区指的是在分布式集群中,节点之间由于网络不通,导致集群中节点形成不同的子集,子集中节点间的网络相通,而子集和子集间网络不通。网络分区是子集与子集之间在网络上相互隔离了。

如何判断是否发生了网络分区?

在分布式集群中,不同的集群架构网络分区的形态略有不同。要判断是否发生了网络分区,需要弄清楚不同的分布式集群架构,即集中式架构和非集中式架构中的网络分区形态是什么样的。

集中式架构的网络分区形态

集中式架构中,Master 节点通常以一主多备的形式部署,Slave 节点与 Master 节点相连接,Master 节点的主和备之间会通过心跳相互通信。

以 Master 节点主备部署为例,如下图所示,集中式架构中的网络分区主要是主节点与备节点之间网络不通,且一部分 Slave 节点只能与主 Master 节点连通,另一部分只能与备 Master 节点连通。

在这里插入图片描述

非集中式架构中的网络分区形态

如下图所示,非集中式架构中,节点是对称的,因此网络分区的形态是形成不同子集,子集内节点间可互相通信,而子集之间的节点不可通信。比如,子集群 1 中 Node1、Node2 和 Node4 可以相互通信,子集群 2 中 Node3 和 Node5 也可以相互通信,但子集群 1 和 子集群 2 之间网络不通。

在这里插入图片描述

从集中式和非集中式这两种分布式集群架构的网络分区形态可以看出,要判断是否形成网络分区,最朴素的方法就是判断节点之间心跳是否超时,然后将心跳可达的节点归属到一个子集中

由于非集中式系统中,每个节点都是对等的、提供的服务相同,所以当多个子集群之间不可达,或部分节点出现故障后,尽管提供的服务质量(SLA)可能会下降,但并不影响这些剩余节点或子集群对外提供服务。所以,重点是集中式系统的网络分区问题

网络分区最微妙的地方在哪里?

在工作和生活中遇到一个问题,本能反应估计是有问题就解决问题好了。而网络分区最微妙的地方在于,很难通过程序去判断问题到底出在哪里,而只能通过心跳等手段知道部分节点的网络不可达了。

但导致节点不可达的原因有很多,有可能是网络的原因,也有可能是节点本身的问题。无法通过一些症状就判断出是否真的产生了分区。也很难通过程序去判断这个问题是不是很快就会被恢复。这也是应对网络分区问题最微妙的地方。

网络分区出现概率较高的场景是什么?

网络分区肯定是就同一个集群而言的。对于不同集群来说, 正是因为集群间本就没有太多的交互,才需要从逻辑上分割成不同的集群,这些逻辑上不同的集群本就是可以独立对外提供服务的。

当集群跨多个网络时,容易出现网络分区的情况, 比如一个业务集群部署在多个数据中心时。所以,集群跨多网络部署时,就是网络分区出现概率较高的场景。

网络分区有哪些常见的处理方法?

假如采用一种非常激进的方式去处理,即一旦发现节点不可达,则将不可达节点从现有集群中剔除,并在这个新集群中选出新的主。

以图 1 所示集中式集群为例,当备 Master、Slave3 和 Slave4 节点检测到主 Master、 Slave1 和 Slave2 节点不可达时,剔除这些不可达节点后,备 Master 升主,连同 Slave3 和 Slave4 节点组成一个新的集群。

如果不可达是由于节点故障导致的,那么这种策略没有任何问题。这些剩余节点组成的集群可以继续对外提供服务。但如果不可达是因为网络故障引起的,那么集群中的另一个子集,即主 Master、Slave1 和 Slave2,也会采用同样的策略,仍然对外提供服务。这时集群就会出现双主问题了。

假如采用一种保守的方式去处理,即节点一旦发现某些节点不可达,则直接停止自己的服务。这样确实解决了双主的问题,但因为不同分区之间的不可达是相互的,且所有的分区都采取了这种停服策略,就会导致系统中所有的节点都停止服务,整个系统完全不可用。 这显然也不是我们想看到的。

当系统中出现节点不可达后,不出现双主的情况下,四种均衡的网络分区处理方法,即 Static Quorum、Keep Majority、设置仲裁机制和基于共享资源的方式。

方法一:通过 Static Quorum 处理网络分区

Static Quorum 是一种固定票数的策略。在系统启动之前,先设置一个固定票数。当发生网络分区后,如果一个分区中的节点数大于等于这个固定票数,则该分区为活动分区。

为了保证发生分区后,不会出现多个活动分区,导致出现双主或多主的问题,需要对固定票数的取值进行一些约束,既:固定票数≤ 总节点数≤2* 固定票数 - 1。

这个策略的优点是,简单、容易实现,但却存在两个问题:

  • 对于分区数比较少的时候,比方 2 个分区时,该策略很容易选出一个唯一的活动分区。但是,当活动分区非常多的时候,由于各个分区的票数分散,不容易找到一个满足条件的分区,没有活动分区也就意味着整个集群不可用了。
  • 由于固定票数是固定不变的,所以不适用于集群中有动态节点加入的场景。

方法二:通过 Keep Majority 处理网络分区

Keep Majority 是保留具备大多数节点的子集群。由于不限定每个分区的节点数超过一个固定的票数,所以可以应用于动态节点加入的场景。

假设,集群数为 n,出现网络分区后,保留的子集群为节点数 w≥n/2 的集群。为防止出现双主或两个集群同时工作的情况,通常将集群总节点数 n 设置为奇数。

若集群总数为偶数,比如图 1 集中式架构的例子中,子集群 1 和 2 都包含 2 个 Slave 节点,就会导致两个子集群同时存活,在业务场景只允许一个主的情况下,会导致业务运行不正确。

如果集群总节点数为偶数,两个子集群节点数均为总数一半时,可以在 Keep Majority 的基础上,叠加一些策略,比如保留集群节点 ID 最小的节点所在的子集群。如图 1 所示,假设集群节点总数为 6,现在因为网络故障形成网络分区子集群 1{主 Master,Slave1, Slave2}和子集群 2{备 Master,Slave3, Slave4},假设 Slave1 是 ID 最小的节点,那么此时要保留包含 Slave1 的子集群 1。

虽然 Keep Majority 方法可以解决动态节点加入的问题,但也不适用于产生多分区的场景。因为随着分区数增多、节点分散,也难以在众多分区中出现一个节点数 w≥n/2 的分区。

集群跨多个网络部署时更容易产生网络分区,因此不推荐采用 Static Quorum 和 Keep Majority 方法去处理跨多网络集群的网络分区问题。

方法三:通过设置仲裁机制处理网络分区

设置仲裁机制的核心是,引入一个第三方组件或节点作为仲裁者,该仲裁者可以与集群中的所有节点相连接,集群中所有节点将自己的心跳信息上报给这个中心节点。因此,该中心节点拥有全局心跳信息,可以根据全局心跳信息判断出有多少个分区。当出现网络分区后,由 仲裁者确定保留哪个子集群,舍弃哪些子集群。

如下图所示,假设引入 Node0 作为第三个节点,该节点 IP 为 10.12.24.35,当出现网络分区子集群 1{Node1, Node3}和子集群 2{Node2, Node4}时,每个子集群中选择一个 Leader 节点并 ping 一下 Node0 的 IP,能 ping 通则保留,否则舍弃。比如下图中,子集群 1 可以 ping 通,子集群 2 ping 不通,因此保留子集群 1。

在这里插入图片描述

方法四:基于共享资源的方式处理网络分区

分布式锁是实现多个进程有序、避免冲突地访问共享资源的一种方式。

基于共享资源处理网络分区的核心,类似于分布式锁的机制。哪个子集群获得共享资源的锁,就保留该子集群。获得锁的集群提供服务,只有当该集群释放锁之后,其他集群才可以获取锁。

这种方式的问题是,如果获取锁的节点发生故障,但未释放锁,会导致其他子集群不可用。 因此,这种方式适用于获取锁的节点可靠性有一定保证的场景。

基于仲裁和共享资源的网络分区处理方法,都是依赖一个三方的节点或组件,借助这个第三方来保证系统中同时只有一个活动分区。所以,这两种处理方法适用于有一个稳定可靠的三方节点或组件的场景。

总结

网络分区的处理方法本质是在产生分区后,选出一个分区,保证同时最多有一个分区对外提供服务。基于此的四种常见的处理方法,包括 Static Quorum、Keep Majority、设置仲裁机制和基于共享资源的方式。

  • 基于 Static Quorum 的方法,因为涉及固定票数策略,所以不适用于处理多个分区,以及有动态节点加入的场景;
  • 基于 Keep Majority 的方法,可以解决动态节点场景下分区问题,但因为要求子集群节点数≥1/2 总节点数,所以也不适用于处理多个分区的情 况;
  • 基于仲裁和共享资源的网络分区处理方法,其实都是依赖一个三方的节点或组件,所以适用于有一个稳定可靠的三方节点或组件的场景。
  • 5
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
第1节 课程概述 [免费观看] 00:12:22分钟 | 第2节 课程背景 [免费观看] 00:09:12分钟 | 第3节 纵观大型网站架构发展,总结持久化部分需要应对的问题 [免费观看] 00:27:12分钟 | 第4节 操作系统安装以及配置 00:31:22分钟 | 第5节 在CentOS上通过yum安装mysql5.7 00:15:32分钟 | 第6节 mysql初次见面-mysql5.7的用户以及安全策略 00:05:34分钟 | 第7节 mysql初次见面续-mysql基本操作 00:37:36分钟 | 第8节 认识主从复制 00:15:01分钟 | 第9节 主从复制的准备工作01-mysql用户以及权限 00:12:11分钟 | 第10节 主从复制的准备工作02-binlog日志详解 00:33:23分钟 | 第11节 主从实战01-准备环境 00:26:06分钟 | 第12节 主从实战02-主节点配置 00:06:19分钟 | 第13节 主从实战03-从节点配置 00:10:45分钟 | 第14节 java操作主从01 00:24:26分钟 | 第15节 java操作主从02 00:13:48分钟 | 第16节 主主复制 00:32:23分钟 | 第17节 负载均衡概述以及环境准备 00:20:42分钟 | 第18节 搭建负载均衡-01 00:22:54分钟 | 第19节 搭建负载均衡-02 00:06:06分钟 | 第20节 启动haproxy的监控功能 00:14:52分钟 | 第21节 高可用以及环境准备 00:40:14分钟 | 第22节 搭建keepalived 00:19:42分钟 | 第23节 Keepalived配置简介 00:11:01分钟 | 第24节 Keepalived配置邮件 00:42:27分钟 | 第25节 Keepalived其他配置 00:12:13分钟 | 第26节 分库分表概述 00:12:18分钟 | 第27节 逻辑分表01-水平分表 00:32:43分钟 | 第28节 逻辑分表02-水平分表续及垂直分表 00:13:36分钟 | 第29节 表分区 00:42:19分钟 | 第30节 数据库间件01-认识mycat 00:22:32分钟 | 第31节 数据库间件02-mycat安装 00:18:18分钟 | 第32节 数据库间件03-mycat的helloworld 00:31:11分钟 | 第33节 数据库间件04-mycat的初识 00:13:57分钟 | 第34节 数据库间件05-mycat的数据切分 00:13:50分钟 | 第35节 数据库间件06-mycat的读写分离-01 00:11:16分钟 | 第36节 数据库间件06-mycat的读写分离-02 00:24:06分钟 | 第37节 数据库间件06-mycat的读写分离03-读写分离补充 00:03:37分钟 | 第38节 数据库间件07-mycat的高可用-01 00:10:01分钟 | 第39节 数据库间件08-mycat的高可用-02 00:06:13分钟 | 第40节 数据库间件09-mycat集群 00:08:08分钟 | 第41节 mysql查询缓存 00:08:17分钟 | 第42节 数据库切分概述 00:37:09分钟 | 第43节 java环境配置 00:13:42分钟 | 第44节 水平切分原理及单表切分后的操作 00:47:46分钟 | 第45节 水平切分原理及单表切分后的操作-2 00:19:32分钟 | 第46节 水平切分多表关联操作 00:38:14分钟 | 第47节 垂直切分原理及操作 00:17:23分钟 | 第48节 全局序列号 00:21:35分钟 | 第49节 数据库切分策略-分片枚举 00:35:49分钟 | 第50节 数据库切分策略-hash 00:41:16分钟 | 第51节 数据库切分策略-范围约定 00:17:20分钟 | 第52节 数据库切分策略-取模 00:13:54分钟 | 第53节 数据库切分策略-按日期分片 00:17:43分钟 | 第54节 全局表 00:04:27分钟 | 第55节 认识MyCat 00:13:55分钟 | 第56节 部署MyCat 00:20:20分钟 | 第57节 使用MyCat完成简单的数据库分片 00:28:58分钟 | 第58节 MyCat分片策略 00:13:08分钟 | 第59节 MyCat全局表配置 00:05:18分钟 | 第60节 MyCatER表配置 00:20:27分钟 | 第61节 另外一种切分方式-使用客户端组件的方式实现数据库分 00:06:20分钟 |

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

海陆云

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值