首页 > 其他分享 >第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?

时间:2022-12-20 15:05:22浏览次数:67  
标签:14 mgr Primary MGR Wireshark 节点 view


第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_监控

本文关键字:MGR、监控、Wireshark

问题

在一个 MGR 集群里,一个节点异常退出后,MySQL 会如何进行调度?异常的节点什么时候会被踢出集群?

实验

实验开始前,给大家分享一个小经验:选择合适的观测工具,如果没有,就创造一个。

我们先使用三台虚拟机,创建一个 MGR 的集群。MySQL 的版本是 5.7.20(之所以使用低版本的 MySQL,因为恐怕没有人能说清楚这个低版本的 MGR 的行为,不能扯淡只能观测)。

这次我们忽略这一操作步骤,只看一下创建好的集群:

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_MGR_02


检查一下谁是 Primary:

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_抓包_03


现在我们得选择一个观测工具了。我们知道 MGR 需要通过网络来相互沟通,对集群内的节点状况达成一致。通过抓包对 MGR 的行为进行分析,看上去是个不错的主意。

不过 Wireshark 并不支持分析 MGR 的网络协议,我们只能自己创造一个 Wireshark 的分析插件(dissector)。

此处我们忽略创造插件的过程,直接拿来用就可以了。

我们访问:

​https://github.com/actiontech/wireshark-dissector-mysql-group-replicaiton/releases​

下载 Wireshark 的安装包,并安装好:

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_监控_04


我们在 MGR 的 Primary 节点(test-mgr-1)上抓包:

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_监控_05


然后将一个节点(test-mgr-3)干掉:

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_Wireshark_06


我们用刚安装的 Wireshark 打开抓包的文件 test-mgr-1.cap,并使用 MGR 协议解开抓包:

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_MGR_07


效果如图:

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_监控_08


我们现在为 Wireshark 的列表增加一列,将 MGR 的信息类型显示出来:

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_抓包_09


第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_MySQL_10

这一列的公式为:mgr.app_data.body.cargo_type

这样我们就能看到 MGR 的信息类型:

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_MGR_11


现在我们通过过滤公式,找到特定类型的 MGR 信息:

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_MySQL_12

可以看到 MGR 的 Primary(10.186.61.45,也就是 test-mgr-1)向另一个存活节点(10.186.61.71,也就是 test-mgr-2)发送了三个信息,分别是 view_msg,remove_node_type,view_msg。我们仔细看看这三个包的详细信息:

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_MGR_13


第一个包,是 Primary 发出的 view 信息(view 是 MGR 的各个节点的状态),可以看到这个 view 的信息是:第一个节点在线,第二个节点在线,第三个节点离线。

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_监控_14


第二个包是删除节点的通知,Primary 通知其他节点,将删除离线的节点三。

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_Wireshark_15


第三个包是一秒之后发送的,Primary 通知其他节点新的 view 是什么样的:新的 view 只有两个节点了。

通过抓包,我们看到了 MGR 各个节点间的信息交换,借此理解 MGR 节点间的调度行为。

在一个节点崩溃后,Primary 节点很快就向全员更新了某节点离线的信息。然后将其踢出集群,并将决定通知全员。

希望我们创造的这个 Wireshark 插件,可以帮助大家理解 MGR 的调度行为,也欢迎大家提需求或缺陷。


关于 MySQL 的技术内容,你们还有什么想知道的吗?赶紧留言告诉小编吧!

第14问:在 MGR 集群里,一个节点异常退出后,会发生什么?_监控_16


标签:14,mgr,Primary,MGR,Wireshark,节点,view
From: https://blog.51cto.com/u_15077536/5955409

相关文章

  • pgpool_II节点状态问题(pgpool_status)
    环境:OS:Centos7PG:14pgpool:4.4通过vip登录发现主节点状态一直是down,重启该节点的pgpool_II也没有用[postgres@pg2pgpool-II]$psql-h192.168.1.199-p9999-Up......
  • PowerDotNet平台化软件架构设计与实现系列(14):平台建设指南
    软件开发中常见的几种不同服务模型包括SaaS(软件即服务)、LaaS(许可即服务)、PaaS(平台即服务)、CaaS(容器即服务)、IaaS(基础设施即服务)和FaaS(功能即服务)。很多人认为IaaS和FaaS是......
  • Osx10.14升级watchman踩坑记
    背景使用watchman检测文件变化通知非常的好用,但有些时候会出现watchman占用内存和CPU特别疯狂,通过watch-del也无济与事,由于watchman的版本2021.09.13比......
  • P1314 聪明的质监员(题解)
    题目小T是一名质量监督员,最近负责检验一批矿产的质量。这批矿产共有\(n\)个矿石,从\(1\)到\(n\)逐一编号,每个矿石都有自己的重量\(w_i\)以及价值\(v_i\)。检验......
  • Osx10.14升级watchman踩坑记
    背景使用​​watchman​​检测文件变化通知非常的好用,但有些时候会出现watchman占用内存和CPU特别疯狂,通过​​watch-del​​也无济与事,由于watchman的版本......
  • 力扣025 K组中的反向节点
    力扣025K组中的反向节点题目:给定链表的,一次反转列表的节点,并返回修改后的列表。head``kk`是一个正整数,小于或等于链表的长度。如果节点数不是节点的倍数,那么最终省略......
  • linux设备树实现多个中断父(interrupt-parent)节点
    方法一: interrupts-extended: 指定中断和父中断的另一种形式,允许多个父中断。这优先于'interrupts'和'interrupt-parent'。#interrupt-cells=<2>;interrupts-ext......
  • 149-gat1400对接(作为上级,与下级对接)
    作为上级,要支持下级的注册、保活、注销、校时的请求。提供的url路径:序号功能URI请求方法1注册/VIID/System/RegisterPOST2注销/VIID/System/UnRegiste......
  • 2022-2023-1 20221420 漆心雨《实验八-Web部署》
    过程1根据博客《openEuler中基于LAMP部署WordPress》进行实验(部分过程截图)实验结果:进行到访问ip/wp-config.php时出现问题,显示无法访问文件。问题:进行到访问ip/wp-......
  • [Typescript] 140. Extreme - Integers Comparator
    Implementatype-levelintegerscomparator.We'veprovidedanenumforindicatingthecomparisonresult,likethis:If a isgreaterthan b,typeshouldbe......