一致性hash算法是什么?

作者&投稿:晨芝 (若有异议请与网页底部的电邮联系)
~

一致性哈希算法是在1997年由麻省理工学院提出的一种分布式哈希(DHT)算法。其设计目标是为了解决因特网中的热点(Hot spot)问题,初衷和CARP十分类似。

一致性Hash是一种特殊的Hash算法,由于其均衡性、持久性的映射特点,被广泛的应用于负载均衡领域,如nginx和memcached都采用了一致性Hash来作为集群负载均衡的方案。

一致性哈希算法的目标是,当K个请求key发起请求时。后台增减节点,只会引起K/N的key发生重新映射。即一致性哈希算法,在后台节点稳定时,同一key的每次请求映射到的节点是一样的。而当后台节点增减时,该算法尽量将K个key映射到与之前相同的节点上。

优点

可扩展性。一致性哈希算法保证了增加或减少服务器时,数据存储的改变最少,相比传统哈希算法大大节省了数据移动的开销。

更好地适应数据的快速增长。采用一致性哈希算法分布数据,当数据不断增长时,部分虚拟节点中可能包含很多数据、造成数据在虚拟节点上分布不均衡,此时可以将包含数据多的虚拟节点分裂,这种分裂仅仅是将原有的虚拟节点一分为二、不需要对全部的数据进行重新哈希和划分。

虚拟节点分裂后,如果物理服务器的负载仍然不均衡,只需在服务器之间调整部分虚拟节点的存储分布。这样可以随数据的增长而动态的扩展物理服务器的数量,且代价远比传统哈希算法重新分布所有数据要小很多。

以上内容参考:百度百科-一致性哈希




区块链哈希指的是什么(区块链哈希顿)
在这一过程中,哈希算法发挥了重要作用。 散列算法是区块链中保证交易信息不被篡改的单向密码机制。区块链通过散列算法对一个交易区块中的交易进行加密,并把信息压缩成由一串数字和字母组成的散列字符串。区块链的散列值能够唯一而准确地标识一个区块。在验证区块的真实性时,只需要简单计算出这个区块的散列值,如果没有...

什么是区块链加密模型(区块链加密概念股)
ECIES:是一种集成加密方案,也可称为一种混合加密方案,它提供了对所选择的明文和选择的密码文本攻击的语义安全性。ECIES可以使用不同类型的函数:秘钥协商函数(KA),秘钥推导函数(KDF),对称加密方案(ENC),哈希函数(HASH),H-MAC函数(MAC)。 ECC是椭圆加密算法,主要讲述了按照公私钥怎么在椭圆上产生,并且不可逆。ECDS...

哈希函数区块链是什么(哈希值是不是区块链交易id)
区块链技术中的哈希算法是什么? 1.1.简介 计算机行业从业者对哈希这个词应该非常熟悉,哈希能够实现数据从一个维度向另一个维度的映射,通常使用哈希函数实现这种映射。通常业界使用y=hash(x)的方式进行表示,该哈希函数实现对x进行运算计算出一个哈希值y。 区块链中哈希函数特性: 函数参数为string类型; 固定大小输出;...

MD5和Hash有什么区别和联系,尽量用简洁的语言描述
Hash是一种特殊的算法,MD5就是其中常用的一种。它的算法的特征是不可逆性,并且才计算的时候所有的数据都参与了运算,其中任何一个数据变化了都会导致计算出来的Hash值完全不同,所以通常用来校验数据是否正确或用作身份验证。常见的,论坛里面用户的密码是经过MD5等Hash算法算出来的Hash值进行保存的。在...

如何设计安全的用户登录功能
1、首先第一步就是要进行登录用户的视图代码编写,然后就是进行设置name属性即可。2、接着就是进行测试用户登录功能,这时候注意的是如果该数据库中没有该用户就提示到注册页面,让用户注册,注册后就可以登录了,如下图所示。3、然后急速进行注册视图代码编写,设置name属性即可。4、接着就是进行测试...

区块链时间如何生成?
哈希的不可修改性 区块与哈希是一一对应的,每个区块的哈希都是针对"区块头"(Head)计算的。也就是说,把区块头的各项特征值,按照顺序连接在一起,组成一个很长的字符串,再对这个字符串计算哈希。 Hash=SHA256(区块头) 上面就是区块哈希的计算公式,SHA256是区块链的哈希算法。注意,这个公式里面只包含区块头,不包...

区块链为什么不会误记(区块链为什么不会误记数据呢)
区块链具有不可篡改的特性,是由哈希算法保证的。 什么是哈希算法\/Hash: 安全哈希算法的特点: 哈希算法的作用: 假设我们相信一个安全的哈希算法:如果H(x)=H(y),则x=y 常用的哈希算法: 比特币使用两种哈希算法: 假设这个区块有5笔交易,首先,对每一笔交易进行第一hash,也就是2次SHA-256的运算,得到5个哈希值...

如何安全的存储密码
错误的方式:双重hash和古怪的hash函数 这一节讨论另外一个常见的hash密码的误解:古怪的hash算法组合。人们可能解决的将不同的hash函数组合在一起用可以让数据更安全。但实际上,这种方式带来的效果很微小。反而可能带来一些互通性的问题,甚至有时候会让hash更加的不安全。本文一开始就提到过,永远不要尝试自己写hash算法...

区块链如何证明真实性原理,区块链技术原理与实践
哈希算法在区块链中得到广泛使用,例如区块中,后一个区块均会包含前一个区块的哈希值,并且以后一个区块的内容+前一个区块的哈希值共同计算后一个区块的哈希值,保证了链的连续性和不可篡改性。 二、加解密算法 加解密算法是密码学的核心技术,从设计理念上可以分为两大基础类型:对称加密算法与非对称加密算法。根据...

MD5加密和MD5hash的区别
MD5加密和MD5 hash的区别为:摘要不同、攻击强度不同、运行速度不同。一、摘要不同 1、MD5加密:MD5加密摘要比MD5摘要短32bit,是264 是数量级的操作。2、MD5 hash:MD5 hash摘要比MD5摘要长32bit,是280 数量级的操作。二、攻击强度不同 1、MD5加密:MD5加密对于强行攻击,产生任何一个报文的强度...

梅县17778442355: 什么叫memcache一致性hash -
春晴安塞: 我们的memcache客户端(这里我看的spymemcache的源码),使用了一致性hash算法ketama进行数据存储节点的选择.与常规的hash算法思路不同,只是对我们要存储数据的key进行hash计算,分配到不同节点存储.一致性hash算法是对我们要存储数据的服务器进行hash计算,进而确认每个key的存储位置.

梅县17778442355: 当hash值取模后的值相同时,都有什么处理方式 -
春晴安塞: sh 为了解决这个问题,需要采用一致性hash算法(consistent hash) 相对于取模的算法,一致性hash算法除了计算key的hash值外,还会计算每个server对应的hash值,然后将这些hash值映射到一个有限的值域上(比如0~2^32).通过寻找hash值大于hash(key)的最小server作为存储该key数据的目标server.如果找不到

梅县17778442355: 一致性hash虚拟节点怎么理解 -
春晴安塞: 一致性哈希基本解决了在P2P环境中最为关键的问题——如何在动态的网络拓扑中分布存储和路由.每个节点仅需维护少量相邻节点的信息,并且在节点加入/退出系统时,仅有相关的少量节点参与到拓扑的维护中.所有这一切使得一致性哈希成...

梅县17778442355: 分布式系统常用的一致性算法有哪些 -
春晴安塞: 在做服务器负载均衡时候可供选择的负载均衡的算法有很多,包括: 轮循算法(Round Robin)、哈希算法(HASH)、最少连接算法(Least Connection)、响应速度算法(Response Time)、加权法(Weighted )等.其中哈希算法是最为常...

梅县17778442355: 一致性hash和paxos什么区别 -
春晴安塞: 一致性算法:用于保证在分布式系统中每个节点都顺序执行相同的操作序列,在每一个指令上执行一致性算法就能够保证最终各个节点的数据都是一致的.Paxos就是用于解决一致性问题的算法,有多个节点就会存在节点间通信的问题,

梅县17778442355: 一致性哈希算法怎么保证数据的一致性 -
春晴安塞: 一致性哈希(Consistent Hashing)和数据一致性没有任何关系,这是个关键的理解错误. 一致性哈希只是保证在分布式结构下,哈希结果不会因为某个 node 挂掉而使得所有的键都不能用.在你的图里面,如果 node2 挂掉了,且没有什么自动错误恢复机制存在的话,读写 node2 的键会失败而不是自动落到 node4 上面,所以不存在数据是否一致的问题

梅县17778442355: memcache 一致性hash 为什么 2的32 -
春晴安塞: 因为一致性hash算法是来做服务器的负载均衡,而服务器的IP地址是32位,所以是2^32-1次方的数值空间

梅县17778442355: 一致性哈希 java实现 怎么映射到圆环上 -
春晴安塞: 一致性哈希提出了在动态变化的Cache环境中,哈希算法应该满足的4个适应条件:单调性是指如果已经有一些内容通过哈希分派到了相应的缓冲中,又有新的缓冲区加入到系统中,那么哈希的结果应能够保证原有已分配的内容可以被映射到新...

梅县17778442355: simhash算法相似度达到多少可以认为内容一致 -
春晴安塞: SIM = Structural SIMilarity(结构相似性),这是一种用来评测图像质量的一种方法.由于人类视觉很容易从图像中抽取出结构信息,因此计算两幅图像结构信息的相似性就可以用来作为一种检测图像质量的好坏. 首先结构信息不应该受到照明的影响,

梅县17778442355: php的memcached分布式hash算法,如何解决分布不均?crc32这个算法没办法把key值均匀的分布出去 -
春晴安塞: memcached的总结和分布式一致性hash 当前很多大型的web系统为了减轻数据库服务器负载,会采用memchached作为缓存系统以提高响应速度. 目录: (http://houdunwang.com/lesson.html) memchached简介 hash 取模 一致性hash 虚拟节...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网