跳到主要内容
极客日志极客日志
首页博客AI提示词GitHub精选代理工具
搜索
|注册
博客列表
编程语言算法

Gossip 协议解读

Gossip 协议是一种用于分布式数据库系统副本节点数据同步的流言算法。其核心机制是周期性随机向邻居节点散播消息,具有扩展性强、容错性好、去中心化及收敛速度快等优势。主要缺点包括消息延迟和冗余。通信模式分为 Push、Pull 和 Push/Pull,其中 Push/Pull 收敛速度最快且能保证周期内完全一致。该协议适用于对实时性要求不高的分布式场景。

虚拟内存发布于 2025/1/8更新于 2026/4/231 浏览
Gossip 协议解读

Gossip 流言算法

作用

  • 这个协议的作用就像其名字表示的意思一样,非常容易理解
  • 它的方式其实在我们日常生活中也很常见,比如电脑病毒的传播,森林大火,细胞扩散等等
  • 主要用在分布式数据库系统中各个副本节点同步数据之用

信息同步过程演示

前提设定

  • Gossip 是周期性的散播消息,把周期限定为 1 秒
  • 被感染节点随机选择 k 个邻接节点(fan-out)散播消息,这里把 fan-out 设置为 3,每次最多往 3 个节点散播
  • 每次散播消息都选择尚未发送过的节点进行散播
  • 收到消息的节点不再往发送节点散播,比如 A -> B,那么 B 进行散播的时候,不再发给 A
  • Gossip 过程是异步的,也就是说发消息的节点不会关注对方是否收到,即不等待响应;不管对方有没有收到,它都会每隔 1 秒向周围节点发消息。异步是它的优点,而消息冗余则是它的缺点

Gossip 的特点(优势)

  1. 扩展性
  • 网络可以允许节点的任意增加和减少,新增加的节点的状态最终会与其他节点一致
  1. 容错
  • 网络中任何节点的宕机和重启都不会影响 Gossip 消息的传播,Gossip 协议具有天然的分布式系统容错特性
  1. 去中心化
  • Gossip 协议不要求任何中心节点,所有节点都可以是对等的,任何一个节点无需知道整个网络状况,只要网络是连通的,任意一个节点就可以把消息散播到全网
  1. 一致性收敛
  • Gossip 协议中的消息会以一传十、十传百一样的指数级速度在网络中快速传播,因此系统状态的不一致可以在很快的时间内收敛到一致。消息传播速度达到了 logN
  1. 简单
  • Gossip 协议的过程极其简单,实现起来几乎没有太多复杂性

Gossip 的缺陷

  • 分布式网络中,没有一种完美的解决方案,Gossip 协议跟其他协议一样,也有一些不可避免的缺陷,主要是两个:

  • 消息的延迟

  • 由于 Gossip 协议中,节点只会随机向少数几个节点发送消息,消息最终是通过多个轮次的散播而到达全网的,因此使用 Gossip 协议会造成不可避免的消息延迟。不适合用在对实时性要求较高的场景下

  • 消息冗余

  • Gossip 协议规定,节点会定期随机选择周围节点发送消息

  • 而收到消息的节点也会重复该步骤,因此就不可避免的存在消息重复发送给同一节点的情况

  • 造成了消息的冗余,同时也增加了收到消息的节点的处理压力

  • 而且,由于是定期发送,因此,即使收到了消息的节点还会反复收到重复消息,加重了消息的冗余

Gossip 中的通信模式

  • 在 Gossip 协议下,网络中两个节点之间有三种通信方式:

  • Push: 节点 A 将数据 (key,value,version) 及对应的版本号推送给 B 节点,B 节点更新 A 中比自己新的数据

  • Pull:A 仅将数据 key, version 推送给 B,B 将本地比 A 新的数据(Key, value, version)推送给 A,A 更新本地

  • Push/Pull:与 Pull 类似,只是多了一步,A 再将本地比 B 新的数据推送给 B,B 则更新本地

  • 如果把两个节点数据同步一次定义为一个周期,则在一个周期内,Push 需通信 1 次,Pull 需 2 次,Push/Pull 则需 3 次

  • 虽然消息数增加了,但从效果上来讲,Push/Pull 最好,理论上一个周期内可以使两个节点完全一致

  • 直观上,Push/Pull 的收敛速度也是最快的

目录

  1. Gossip 流言算法
  2. 信息同步过程演示
  3. Gossip 的特点(优势)
  4. Gossip 的缺陷
  5. Gossip 中的通信模式
  • 💰 8折买阿里云服务器限时8折了解详情
  • 💰 8折买阿里云服务器限时8折购买
  • 🦞 5分钟部署阿里云小龙虾了解详情
  • 🤖 一键搭建Deepseek满血版了解详情
  • 一键打造专属AI 智能体了解详情
极客日志微信公众号二维码

微信扫一扫,关注极客日志

微信公众号「极客日志」,在微信中扫描左侧二维码关注。展示文案:极客日志 zeeklog

更多推荐文章

查看全部
  • 大语言模型应用指南:Gorilla
  • 程序员如何入局 AI 大模型及职业发展路径
  • LeetCode 第 5 题:最长回文子串
  • Python 自学项目资源整理
  • 提升 SQL 技能的 7 个最佳练习平台
  • 基于SpringBoot的网上租赁系统设计与实现
  • Java 企业人事工资管理系统设计与实现
  • Linux LVM 磁盘管理工具详解:物理卷、卷组与逻辑卷操作
  • 软件设计各个模块分析
  • 交换瓶子问题 Java 最小交换次数解法
  • Java Cookie 技术原理与应用
  • CopyOnWriteArrayList 源码解析
  • Python 学习后如何找工作及就业方向分析
  • Windows 环境下如何将本地代码推送到 Git 远程仓库
  • Vue 中使用 Less 样式预处理
  • 大语言模型框架-Megatron-LM 源码分析
  • CSS 子元素选择器
  • Webpack Loader 一览表
  • ThinkPHP 5.1 环境安装与配置指南
  • Ubuntu SSH 服务安装与配置详解

相关免费在线工具

  • 加密/解密文本

    使用加密算法(如AES、TripleDES、Rabbit或RC4)加密和解密文本明文。 在线工具,加密/解密文本在线工具,online

  • Base64 字符串编码/解码

    将字符串编码和解码为其 Base64 格式表示形式即可。 在线工具,Base64 字符串编码/解码在线工具,online

  • Base64 文件转换器

    将字符串、文件或图像转换为其 Base64 表示形式。 在线工具,Base64 文件转换器在线工具,online

  • Markdown转HTML

    将 Markdown(GFM)转为 HTML 片段,浏览器内 marked 解析;与 HTML转Markdown 互为补充。 在线工具,Markdown转HTML在线工具,online

  • HTML转Markdown

    将 HTML 片段转为 GitHub Flavored Markdown,支持标题、列表、链接、代码块与表格等;浏览器内处理,可链接预填。 在线工具,HTML转Markdown在线工具,online

  • JSON 压缩

    通过删除不必要的空白来缩小和压缩JSON。 在线工具,JSON 压缩在线工具,online