【Gossip 协议】Golang的实现库Memberlist 库简介

news2025/1/18 18:06:53

Gossip 协议简介

Gossip 协议是一种分布式协议,用于在节点之间传播信息,常用于成员管理、故障检测、服务发现等场景。在这个协议中,每个节点定期与其他节点交换信息,最终保证所有节点达到一致的状态。它的工作原理类似于人群中的流言传播(gossip)。

在分布式系统中,Gossip 协议通常用于:

  • 成员管理:节点动态加入和退出集群。
  • 故障检测:节点失效时通过 Gossip 协议通知其他节点。
  • 信息传播:节点之间传播配置信息或状态更新。

Memberlist 库简介

Memberlist 是由 HashiCorp 提供的一个 Go 库,提供了实现 Gossip 协议的功能,帮助开发者轻松管理分布式集群中的节点。Memberlist 库支持集群成员发现、节点健康检测、消息广播等功能,广泛应用于类似 ConsulVault 的分布式系统中。

Gossip 协议在 Memberlist 中的工作原理

  1. 节点加入集群:每个节点启动时会选择一些已知的种子节点进行连接,并通过 Gossip 协议与其他节点交换信息。
  2. 信息传播:节点通过 Gossip 协议定期与其他节点交换状态信息(例如:节点的健康状况、集群的变化等)。
  3. 故障检测:如果一个节点长时间未发送心跳或响应,它将被标记为失效。
  4. 最终一致性:通过不断的 Gossip 交换,集群中的所有节点最终会达到一致的状态。

如何使用 Memberlist 实现 Gossip 协议

下面是一个简单的示例,展示如何使用 Memberlist 库实现 Gossip 协议,创建一个分布式集群并管理节点。

步骤 1:安装 Memberlist

首先,安装 Memberlist 库:

go get github.com/hashicorp/memberlist
步骤 2:创建一个简单的 Gossip 集群

以下代码展示了如何使用 Memberlist 来实现一个简单的 Gossip 协议集群。该示例包括一个节点的加入和集群成员的发现。

package main

import (
	"fmt"
	"github.com/hashicorp/memberlist"
	"gopkg.in/alecthomas/kingpin.v2"
	"strings"
)

func main() {
	bindAddr := kingpin.Flag("bind-addr", "Configuration related to what address to bind to listen on").Default("0.0.0.0").String()
	bindPort := kingpin.Flag("bind-port", "Configuration related to what port to bind to listen on").Default("7946").Int()

	name := kingpin.Flag("name", "node name ").Default("default").String()
	clusterAddress := kingpin.Flag("clusterAddress", "which address for member to join the existing Memberlist").Default("127.0.0.1:7946").String()
	kingpin.Parse()
	/* Create the initial memberlist from a safe configuration.
	   Please reference the godoc for other default config types.
	   http://godoc.org/github.com/hashicorp/memberlist#Config
	*/
	config := memberlist.DefaultLocalConfig()
	config.BindPort = *bindPort
	config.BindAddr = *bindAddr
	config.AdvertisePort = *bindPort
	config.Name = *name
	list, err := memberlist.Create(config)
	if err != nil {
		panic("Failed to create memberlist: " + err.Error())
	}

	// Join an existing cluster by specifying at least one known member.
	existing := strings.Split(*clusterAddress, ",")
	n, err := list.Join(existing)
	if err != nil {
		panic("Failed to join cluster: " + err.Error())
	}
	fmt.Println("total name is ", n)
	// Ask for members of the cluster
	for _, member := range list.Members() {
		fmt.Printf("Member: %s %s\n", member.Name, member.Addr)
	}

	select {}

}

代码解析

上面代码使用了 kingpin 包来解析命令行参数,并使用 memberlist 库来创建一个分布式集群中的节点。

  1. 解析命令行参数,获取节点配置(绑定地址、端口、节点名称、现有集群的地址)。
  2. 使用 memberlist 库创建本地节点配置,并加入现有的集群。
  3. 打印当前集群的所有成员。
  4. 保持程序运行,等待后续操作或事件。
步骤 3:启动多个节点

为了模拟多个节点,你可以运行多个实例。在启动第一个节点后,第二个节点可以通过加入第一个节点的地址来加入集群:

  1. 启动第一个节点:
    go run main.go
    
  2. 启动第二个节点时,加入第一个节点:
    go run main.go
    
步骤 4:查看集群成员

当你启动多个节点后,集群中的节点会自动发现彼此,并通过 Gossip 协议保持同步。每个节点会定期检查其他节点的健康状况,并通过 Gossip 协议同步状态。

在输出中,你将看到类似如下的输出:

Current cluster members:
- Node1
- Node2

这表示 Node1Node2 都已经成功加入了集群,并且通过 Gossip 协议交换了信息。

进阶功能:广播消息与故障检测

除了成员管理外,Memberlist 还支持消息广播和故障检测。下面是一个简单的广播消息的示例:

// 自定义的广播消息
msg := []byte("Hello, this is a broadcast message!")

// 向集群中的所有成员广播消息
for _, node := range list.Members() {
	if err := list.SendTo(node, msg); err != nil {
		log.Println("Error sending message:", err)
	}
}

总结

  1. Gossip 协议:Gossip 协议通过定期的状态交换,使分布式系统中的节点能够自动发现彼此、同步状态和进行故障检测。
  2. Memberlist 库Memberlist 提供了一个简单而强大的方式来实现 Gossip 协议,支持节点管理、故障检测、信息传播等功能。
  3. 示例应用:通过上述示例,您可以轻松创建一个基于 Gossip 协议的分布式集群,自动进行成员发现和状态同步。

Memberlist 是构建高可用、可扩展分布式系统的重要工具,特别适合用于需要动态成员管理、故障检测和信息同步的场景。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2278572.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

ASP.NET Core 中,认证(Authentication)和授权(Authorization)

在 ASP.NET Core 中,认证(Authentication)和授权(Authorization)是两个非常重要的概念。它们确保用户能够安全地访问应用程序,并且在访问过程中能按其权限被正确地控制。接下来,我将详细解释这两…

ThinkPHP 8的一对多关联

【图书介绍】《ThinkPHP 8高效构建Web应用》-CSDN博客 《2025新书 ThinkPHP 8高效构建Web应用 编程与应用开发丛书 夏磊 清华大学出版社教材书籍 9787302678236 ThinkPHP 8高效构建Web应用》【摘要 书评 试读】- 京东图书 使用VS Code开发ThinkPHP项目-CSDN博客 编程与应用开…

基于SpringBoot+Vue的药品管理系统【源码+文档+部署讲解】

系统介绍 基于SpringBootVue实现的药品管理系统采用前后端分离的架构方式,系统实现了用户登录、数据中心、药库管理、药房管理、物资管理、挂号管理、系统管理、基础设置等功能模块。 技术选型 开发工具:idea2020.3Webstorm2020.3 运行环境&#xff…

tomcat状态一直是Exited (1)

docker run -di -p 80:8080 --nametomcat001 你的仓库地址/tomcat:9执行此命令后tomcat一直是Exited(1)状态 解决办法: 用以下命令创建运行 docker run -it --name tomcat001 -p 80:8080 -d 你的仓库地址/tomcat:9 /bin/bash最终结果 tomcat成功启动

递归40题!再见递归

简介:40个问题,有难有易,均使用递归完成,需要C/C的指针、字符串、数组、链表等基础知识作为基础。 1、数字出现的次数 由键盘录入一个正整数,求该整数中每个数字出现的次数。 输入:19931003 输出&#xf…

《leetcode-runner》【图解】【源码】如何手搓一个debug调试器——架构

前文: 《leetcode-runner》如何手搓一个debug调试器——引言 文章目录 设计引入为什么这么设计存在难点1. 环境准备2. 调试程序 仓库地址:leetcode-runner 本文主要聚焦leetcode-runner对于debug功能的整体设计,并讲述设计原因以及存在的难点…

PyTorch使用教程(1)—PyTorch简介

PyTorch是一个开源的深度学习框架,由Facebook人工智能研究院(FAIR)于2016年开发并发布,其主要特点包括自动微分功能和动态计算图的支持,使得模型建立更加灵活‌。官网网址:https://pytorch.org。以下是关于…

用LLM做测试驱动开发:有趣又高效的尝试

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

5-1 创建和打包AXI Interface IP

创建和打包AXI Interface IP的前流程和后流程 step 1 : 选择类型 1: 将当前的工程打包成IP 2: 将当前的BD工程打包成IP 3: 将指定的源码打包成IP 4: 创建一个新的AXI 接口IP 其中3和4是比较常用的,本次…

国家统计局湖北调查总队副总队长张小青一行调研珈和科技农业遥感调查智能化算法

1月15日上午,国家统计局湖北调查总队党组成员、副总队长张小青一行莅临珈和科技开展调研。调研期间,张小青一行实地了解了珈和科技在自动化作物分布提取技术领域的最新成果,深入探讨了作物自动化处理模型在农业调查上应用的创新价值及优化方向…

基于微信小程序的电子点菜系统设计与实现(KLW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导,欢迎高校老师/同行前辈交流合作✌。 技术范围:SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容:…

SQL Server 导入Excel数据

1、选中指定要导入到哪个数据库,右键选择 》任务 》导入数据 2、数据源 选择Excel,点击 下一步(Next) 3、目前 选择OLE DB Provider ,点击 下一步(Next) 4、默认 ,点击 下一步(Next)…

【Excel】【VBA】双列排序:坐标从Y从大到小排列之后相同Y坐标的行再对X从小到大排列

Excel VBA 双列排序 功能概述 这段VBA代码实现了Excel中的双列排序功能,具体是: 跳过前3行表头先按C列数据从大到小排序在C列值相同的情况下,按B列从大到小排序排序时保持整行数据的完整性 流程图 #mermaid-svg-XJERemQluZlM4K8l {font-fa…

【C++】构造函数与析构函数

写在前面 构造函数与析构函数都是属于类的默认成员函数! 默认成员函数是程序猿不显示声明定义,编译器会中生成。 构造函数和析构函数的知识需要建立在有初步类与对象的基础之上的,关于类与对象不才在前面笔记中有详细的介绍:点我…

1月17日星期五今日早报简报微语报早读

1月17日星期五,农历腊月十八,早报#微语早读。 1、广东明确旅馆承担防偷拍责任:应确保客房没有偷窥等设备; 2、商务部:手机补贴不用交旧手机; 3、中国汽车工业协会:坚决反对拜登政府禁止使用中…

【Linux】gdb_进程概念

📢博客主页:https://blog.csdn.net/2301_779549673 📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正! 📢本文由 JohnKi 原创,首发于 CSDN🙉 📢未来很长&#…

深入内核讲明白Android Binder【二】

深入内核讲明白Android Binder【二】 前言一、Binder通信内核源码整体思路概述1. 客户端向服务端发送数据流程概述1.1 binder_ref1.2 binder_node1.3 binder_proc1.4 binder_thread 2. 服务端的binder_node是什么时候被创建的呢?2.1 Binder驱动程序为服务创建binder…

记录一次微信小程序使用云能力开发的过程

对于开发微信小程序云开发不知从何起的同学们,可以当作一次参考。虽说官方有文档,有模板示例,但是这些都是片段或者完整的结果展示。对于初学或者开发经验较少的同学们,可能不知先从那里入手进行第一步的开发。下面解析下构建微信…

初学stm32 --- SPI驱动25Q128 NOR Flash

目录 SPI介绍 SPI结构框图介绍 SPI外设对应的引脚 SPI数据发送与接收 SPI工作原理 SPI 全双工模式的通信机制 从机返回主机之前保存的数据 SPI工作模式介绍 SPI相关寄存器介绍(F1 / F4 / F7) SPI控制寄存器1(SPI_CR1) SPI状…

数据库基础练习1(创建表,设置外键,检查,不为空,主键等约束)安装mysql详细步骤

安装MySQL详细步骤 1. 下载 MySQL 安装程序 访问 MySQL 官方网站:MySQL Downloads。在下载页面,选择 "MySQL Community (GPL) Downloads"。在 "MySQL Community Server" 部分,根据你的操作系统(Windows&…