【分布式命名系统】Distributed Hash Tables (Chord)分布式哈希表

news/2024/5/6 11:26:28/文章来源:https://blog.csdn.net/liuwanqing233333/article/details/127155056

一、背景

1.命名系统:

分布式系统的命名系统主要是为了解决Name 与 Address 的对应问题,即如何使用 Name 找到 Address

几个概念:

Name: 表示名称的字符串
entity: 实体 —— 资源,如硬盘,主机等
Address: 将 Name 赋值给 Access Point , 这个 Access Point 就成为了 Address,即 Address 就是访问点的名字,通过 Address 我们可以找到某种 entity 即资源

2. 解决 Name 到 Address 间映射的其他方法

(1)Flat Name —— 平面命名法

平面命名法通过广播和多波的形式,建立 MapTable ,通过留转发指针的方式解决节点移动问题,但这种方法耗费通信资源,并且大量的转发指针不利于管理

(2)Home-Based Approach —— 基于主站的查找法

通过建立一个主站,保持所有的 Name 和 Address 的映射关系,节点先访问主站,主站将节点要查询的地址返回,节点再根据返回的地址进行下一步操作。但是这种方式,主站存放了大量信息,不符合分布式系统的概念,且不具有地区友好性

在这里插入图片描述
图. 跨地区较远时,来回发送,浪费资源

因此,引入分布式哈希表,即 Chord 这一数据结构,下面重点介绍 Chord 用法


二、Chord —— 分布式哈希表

1. 术语:

Chord 数据结构使用 m 位的标识空间(2的m次方个数字 )指定 node 和 key(m = 128 或 160)

  1. ID: 0 ~ 2 的m次方 - 1 , 表示 Address 和 Name 的所有可用名字
  2. NID(NodeID) 0 ~ 2 的m次方 - 1,用于表示Address,如服务器地址
  3. KID(KeyID) 0 ~ 2 的m次方 - 1,用于表示entity,如文件名

2. 实现方式:

Chord 通过抽象一个环形数据结构的方式,环上的点表示 Address 即 NID,NID通过后继指针连接下一个 NID,并通过用指针将 KID连接到环上的 NID 的方式实现 NID 与 KID 的映射,该算法可以达到查找时 logn 的时间复杂度

(1)示例图:
在这里插入图片描述
示例图解释:
m = 6 说明一共有 (0 ~ 63)个ID 可以用来命名,即 NID (0 ~ 63 之间),且 KID(0~63 之间) 。

  • NID的放置: 图中圆上共有 N1,N8,N14 … 等 NID(即 Address,也可理解为服务器),(N1 - N8 间无节点,N1指向 N8,若加入 N6,则将其加入两者之间,并修改指针即可)。
  • KID的放置: 以 N14 为例,若要插入 K10,则去找 10 的最近后继节点,本图中,节点 10 的最后一个后继节点为 N14,因此将 K10 指向 N14

(2)如何找到某 KID 所在的 NID

  • Basic Query:从某一 NID 开始,依此向其后继节点查找,这样的搜索方式时间复杂度为O(n)显然是非常大的,这不是我们想要的。
  • Finger Table (建立指表):

显然,之所以查找慢,是因为每个NID都只知道找其紧紧相邻的后继节点,因此我们可以通过为每个 NID 建立包含其部分后继 NID 的指表的方式,减低时间复杂度

指表建立方式:

我们知道了建立指表可以减少时间复杂度,就来到了下个问题指表中应该保存那些后继节点,其计算公式为

在这里插入图片描述
找到上述计算公式结果的 下一个后继 NID,保持在指表中,作为 NID = n 节点的指表

示例: N8 的指表中所含后继节点的计算
在这里插入图片描述

通过指表进行查找:

在这里插入图片描述

以上图为例:我们需要 N1 找到 K20,我们就可以现在 N1 的指表中找到 K20 的上一个节点,可以判断为 N8,因此之间转到 N8。然后在 N8 找 K20 的上个节点,可以观察到就是 K20 本身,因此之间转到 K20 即可,查找结束。通过上述过程,我们也可以得出通过建立指表的方式可以极大的降低查找过程的时间复杂度

指表的其他优点:

  • 完全分布式,无中央节点
  • 新增节点容易,变化小

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

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机毕业设计-基于SSM的音乐推荐管理系统

项目摘要 中国风音乐推介网站近年来已成为风靡全球的新兴艺术形式。国内涌现出了大批优秀、有才华的爱好者和许多经久不衰的经典作品。中国风音乐推介网站的兴起打破了音乐界格局,也突破了原有分类唱法发展中的瓶颈,为声乐艺术的发展开辟了新篇章。这种新兴的演唱风格是声乐艺…

【图解HTTP】Web服务器与HTTP的协作

顺心的人大抵一样,坎坷的人各有各的坎坷。也只能坚持自我修行,等待自己的机遇。 文章目录1. Web服务器与HTTP的协作1.1 单台虚拟主机实现多域名1.2 通信数据转发程序:代理、网关、隧道1.2.1 代理1.2.2 网关1.2.3 隧道1.3 缓存1.4 扩展&#x…

【程序语言】-- 编程语言分类和应用

系列文章目录 文章目录系列文章目录前言一、编程语言有哪些二、应用概况1.Python2.Java3.C/C4.JavaScript5.Golang6.R7.Swift8.PHP9.C#9.MATLAB总结前言 一、编程语言有哪些 JavaScriptHTML/CSSPythonSQLJavaNode.jsTypeScriptC#Bash/ShellCPHPCPowerShellGoKotlinRustRubyPe…

Linux:进程

0.前言:冯诺依曼体系结构 冯诺依曼体系结构 电脑中涉及两种类型信号:控制信号、数据信号 计算机硬件构成: 输入设备:显卡、 输出设备:显示器、 存储器(内存):磁盘不算,磁盘算外部设…

LLC谐振电路增益公式推导

LLC谐振电路增益公式推导 图 由图可知 GVoutVinsLm//Rac1sCrsLrsLm//RacG\frac{V_{out}}{V_{in}}\frac{sLm//Rac}{\frac{1}{sCr}sLrsLm//Rac} GVin​Vout​​sCr1​sLrsLm//RacsLm//Rac​ 其中 sLm//RacsLm∗RacsLmRacsLm//Rac\frac{sLm*Rac}{sLmRac} sLm//RacsLmRacsLm∗Rac​…

Java 多线程编程(入门)

目录 一、简单介绍 Thread类 【1】Thread类中一些常用的方法 【2】编写一个简单多线程程序(入门) 二、Java中创建多线程的方法(重点面试题) 1.继承 Thread 类 2.实现 Runnable 接口,重写 run 3.使用匿名内部类&…

(决策树中的)信息熵和样本分类的信息熵计算源代码

目录 一、信息熵 ① 基本概念 ② 计算公式 二、决策树中的信息熵 三、计算数据集样本分类的香农熵的源代码 说明:由于对这部分的知识有所遗忘,因此翻阅资料进行温习,写下本文。 需要注意的是,在本文中,所有中括号…

WPF 控件专题 ContentControl 控件详解

1、ContentControl 介绍 ContentControl 表示包含一段任意类型内容的控件;也叫作内容控件。只包含一个子元素。 ************************************************************************************************************** 2、常用属性介绍 FontFamily&a…

《代码随想录》一刷记录之回溯算法

文章目录前言第9章:回溯法回溯算法理论基础什么是回溯算法回溯法的性能回溯法可以解决的问题理解回溯法回溯法模板组合问题回溯算法剪枝优化组合总和(一)回溯算法剪枝优化电话号码的字母组合回溯算法组合总和(二)回溯算法剪枝优化组合总和&am…

flask数字图像处理系统开发全流程记录(基于OpenCV)

目录一、环境安装1.1 安装虚拟环境1.2 安装Flask二、搭建flask项目框架2.1 创建一个简单项目2.2 渲染html页面2.3 使用Bootstrap美化页面2.4 前后端逻辑交互2.4.1 前端实现2.4.2 后端实现三、部署3.1 Waitress工业级部署3.2 项目打包一、环境安装 1.1 安装虚拟环境 虚拟环境是…

以太网交换机(计算机网络)

目录 一、以太网交换机与网桥 二、交换机与集线器 三、交换式以太网 四、以太网交换机的要点 一、以太网交换机与网桥 1、交换式集线器又称为以太网交换机(switch)或二层交换 机(表明此交换机工作在数据链路层),或直接简称 为交换机。 2…

2022/10/4——基于stm32mp157a的A7核按键中断实验

分析电路图可知三个按键对应的管脚为:KEY1----->PF9 KEY2----->PF7 KEY3----->PF8 本次实验采用延时函数来解决按键按下时的电平抖动问题 功能分析如下 如上图所示 1.需要分析GPIOF章节:设置引脚为输入模式 2.需要分析EXTI章节&#xff1…

人工智能算法一无监督学习(Kmeas聚类)

简介 在前面介绍的线性回归还有逻辑回归它们都是知道x,y然后开始训练模型,这也就是有监督学习的情况,还有如果只是知道x不知道y的情况那么这种就是无监督学习。 描述 需求引入,如果有一千万用户,我们要对用户进行分类。这里由于…

Pytorch深度学习笔记之三(构建一个完整的神经网络)

本篇笔记是基于一个印度人写的《Pytorch深度学习》一书的第二章,主要用来描述一个麻雀虽小五脏俱全的完整的神经网络,包含了建模、训练等。原书的代码基于较老版本的Pytorch,有多处编译不过,笔者都做了调整,并在文末给…

几种常见的概率分布表

参考:《概率论与数理统计 第四版》

Jenkins+Maven+Gitlab+Tomcat 自动化构建打包、部署

一、环境需求 本帖针对的是Linux环境,Windows或其他系统也可借鉴。具体只讲述Jenkins配置以及整个流程的实现。 1.JDK(或JRE)及Java环境变量配置,我用的是JDK1.8。 2.Jenkins 持续集成和持续交付项目。 3.现有项目及gitlab&#…

Redis实战 - 03 RedisTemplate 的 hash 结构

文章目录1. put(H var1, HK var2, HV var3)2. get(H var1, Object var2)3. entries(H key)4. keys(H key)5. values(H key)6. hasKey(H key, Object var2)7. size(H key)8. putAll(H key, Map<? extends HK, ? extends HV> map)1. put(H var1, HK var2, HV var3) 新增…

机器学习之验证曲线绘制-调参可视化-sklearn

验证曲线是什么&#xff1f; 验证曲线和学习曲线的区别是&#xff0c;横轴为某个超参数的一系列值&#xff0c;由此来看不同参数设置下模型的准确率(评价标准)&#xff0c;而不是不同训练集大小下的准确率。 从验证曲线上可以看到随着超参数设置的改变&#xff0c;模型可能从…

Java Web 12.1 Filter 12.1.2 Filter 快速入门

Java Web 【黑马程序员新版JavaWeb基础教程&#xff0c;Java web从入门到企业实战完整版】 12 Filter & Listener & Ajax 文章目录Java Web12 Filter & Listener & Ajax12.1 Filter12.1.2 Filter 快速入门12.1 Filter 12.1.2 Filter 快速入门 【开发步骤】…

论如何参与一个开源项目(上)

写在前面的一些话 说起开源项目&#xff0c;好像人人都懂&#xff1a;不过就是一群人一起写了些东西&#xff0c;并且这些东西是公开的&#xff0c;大家都能看。但要细说&#xff0c;可能大多数的开发者都说不出个所以然&#xff0c;甚至不知道怎么提issue。 所以我就想写这样…