关于一致性hash,这可能是全网最形象生动最容易理解的文档,想做架构师的你来了解一下
问题提出
一致性hash是什么?假设有4台缓存服务器N0,N1,N2,N3,现在需要存储数据OBJECT1,OBJECT2,OBJECT3,OBJECT4,OBJECT5,OBJECT5,OBJECT7,OBJECT8,
我们需要将这些数据缓存到这4台服务器上,相应的问题是
如何设计数据存放策略?即ObjectX 应该存放在哪台服务器上?
为了解决这个问题,我们有如下几个思路。
1. 余数hash方案
采用hash(Objectx)%4来确定服务器节点
假设 hash(OBJECT1)=2,由 2%4=2,可知,Object1则应该存放到节点N2上
假设 hash(OBJECT2)=3,由 3%4=3,可知,Object2则应该存放到节点N3上
假设 hash(OBJECT3)=1,由 1%4=1,可知,Object3则应该存放到节点N1上
假设 hash(OBJECT4)=0,由 1%4=1,可知,Object4则应该存放到节点N0上
假设 hash(OBJECT5)=5,由 5%4=1,可知,Object5则应该存放到节点N1上
假设 hash(OBJECT6)=6,由 6%4=2,可知,Object6则应该存放到节点N2上
假设 hash(OBJECT7)=7,由 7%4=3,可知,Object7则应该存放到节点N3上
假设 hash(OBJECT8)=8,由 8%4=0,可知,Object8则应该存放到节点N0上
假设我们需要读取Object3的数据,则由hash(object3)=1可知,我们只需要访问节点N1即可。
1.1 现在假设N3忽然故障下线
我们面临缓存重新构造的问题
采用hash(Objectx)%3来确定服务器节点
假设 hash(OBJECT1)=2,由 2%3=2,可知,Object1则应该存放到节点N2上
假设 hash(OBJECT2)=3,由 3%3=0,可知,Object2则应该存放到节点N0上
假设 hash(OBJECT3)=1,由 1%3=1,可知,Object3则应该存放到节点N1上
假设 hash(OBJECT4)=0,由 0%3=0,可知,Object4则应该存放到节点N0上
假设 hash(OBJECT5)=5,由 5%3=2,可知,Object5则应该存放到节点N2上
假设 hash(OBJECT6)=6,由 6%3=0,可知,Object6则应该存放到节点N0上
假设 hash(OBJECT7)=7,由 7%3=1,可知,Object7则应该存放到节点N1上
假设 hash(OBJECT8)=8,由 8%3=2,可知,Object8则应该存放到节点N2上
此时为了保证数据的准确性,我们需要
将数据Object2从N3迁移到N0
将数据Object5从N1迁移到N2
将数据Object6从N2迁移到N0
将数据Object7从N3迁移到N1
将数据Object8从N0迁移到N2
1.2 现在假设我们添加一台新的服务器N4
我们面临缓存重新构造的问题
采用hash(Objectx)%5来确定服务器节点
假设 hash(OBJECT1)=2,由 2%5=2,可知,Object1则应该存放到节点N2上
假设 hash(OBJECT2)=3,由 3%5=3,可知,Object2则应该存放到节点N3上
假设 hash(OBJECT3)=1,由 1%5=1,可知,Object3则应该存放到节点N1上
假设 hash(OBJECT4)=0,由 0%5=0,可知,Object4则应该存放到节点N0上
假设 hash(OBJECT5)=5,由 5%5=0,可知,Object5则应该存放到节点N0上
假设 hash(OBJECT6)=6,由 6%5=1,可知,Object6则应该存放到节点N1上
假设 hash(OBJECT7)=7,由 7%5=2,可知,Object7则应该存放到节点N2上
假设 hash(OBJECT8)=8,由 8%5=3,可知,Object8则应该存放到节点N3上
此时为了保证数据的准确性,我们需要
将数据Object2从N3迁移到N0
将数据Object5从N1迁移到N0
将数据Object6从N2迁移到N1
将数据Object7从N3迁移到N2
将数据Object8从N0迁移到N3
从上述俩种情况可以看出,一旦机器数目变化,我们面临大量的缓存变化问题,换言之,缓存大部分失效,很可能会导致雪崩。
2.一致性hash方案
现在我们更换如下策略
0<hash(Objectx)%8<=2 ,则存放在
N0
2<hash(Objectx)%8<=4 ,则存放在N1
4<hash(Objectx)%8<=6 ,则存放在N2
6<hash(Objectx)%8<=8 ,则存放在N3
2.1 现在假设N3忽然故障下线
我们面临缓存重新构造的问题,调整策略如下
0<hash(Objectx)%8<=2 ,则存放在
N0
2<hash(Objectx)%8<=4 ,则存放在N1
4<hash(Objectx)%8<=6 ,则存放在N2
6<hash(Objectx)%8<=8 ,则存放在N0
此时为了保证数据的准确性,我们需要
将数据ObjectX从N3迁移到N0,受影响的数据仅仅N3相关的数据。
2.2 现在假设我们添加一台新的服务器N4
我们面临缓存重新构造的问题,调整策略如下
0<hash(Objectx)%8<=2 ,则存放在
N0
2<hash(Objectx)%8<=4 ,则存放在N1
4<hash(Objectx)%8<=5 ,则存放在N2
5<hash(Objectx)%8<=6 ,则存放在N4
6<hash(Objectx)%8<=8 ,则存放在N3
此时为了保证数据的准确性,我们需要
将数据从N2复制到N4,受影响的仅仅N2相关的用户。
比较上述俩种做法,可见方案2更优. 方案2就是一致性hash
2.3 缺点
机器越少,则每台机器上负载将越不均匀,解决这个问题的方法是添加虚拟节点,调整策略,如下,可以想象,数据越多,分布越均匀。
0<hash(Objectx)%8<=1 ,则存放在
N0
1<hash(Objectx)%8<=2 ,则存放在N1
2<hash(Objectx)%8<=3 ,则存放在N2
3<hash(Objectx)%8<=4 ,则存放在N3
4<hash(Objectx)%8<=5 ,则存放在N0
5<hash(Objectx)%8<=6 ,则存放在N1
6<hash(Objectx)%8<=7 ,则存放在N2
7<hash(Objectx)%8<=8 ,则存放在N3
3. 一致性Hash原理
原理网络上太多,这里不做进一步阐述。
推荐阅读
开源项目golang go语言后台管理框架restgo-admin
推荐阅读
开源项目golang go语言后台管理框架restgo-admin
关于一致性hash,这可能是全网最形象生动最容易理解的文档,想做架构师的你来了解一下的更多相关文章
- 对一致性Hash算法,Java代码实现的深入研究
一致性Hash算法 关于一致性Hash算法,在我之前的博文中已经有多次提到了,MemCache超详细解读一文中"一致性Hash算法"部分,对于为什么要使用一致性Hash算法.一致性 ...
- 转载自lanceyan: 一致性hash和solr千万级数据分布式搜索引擎中的应用
一致性hash和solr千万级数据分布式搜索引擎中的应用 互联网创业中大部分人都是草根创业,这个时候没有强劲的服务器,也没有钱去买很昂贵的海量数据库.在这样严峻的条件下,一批又一批的创业者从创业中获得 ...
- 一致性hash算法详解
转载请说明出处:http://blog.csdn.net/cywosp/article/details/23397179 一致性哈希算法在1997年由麻省理工学院提出的一种分布式哈希(DHT) ...
- 探索c#之一致性Hash详解
阅读目录: 使用场景 算法原理 虚拟节点 代码示例 使用场景 以Redis为例,当系统需要缓存的内容超过单机内存大小时,例如要缓存100G数据,单机内存仅有16G时.这时候就需要考虑进行缓存数据分片, ...
- 一致性hash算法简介
一致性哈希算法在1997年由麻省理工学院提出的一种分布式哈希(DHT)实现算法,设计目标是为了解决因特网中的热点(Hot spot)问题,初衷和CARP十分类似.一致性哈希修正了CARP使用的简单哈希 ...
- 分布式缓存技术memcached学习(四)—— 一致性hash算法原理
分布式一致性hash算法简介 当你看到“分布式一致性hash算法”这个词时,第一时间可能会问,什么是分布式,什么是一致性,hash又是什么.在分析分布式一致性hash算法原理之前,我们先来了解一下这几 ...
- 关于Memcached一致性hash的探究
参考文章 http://blog.chinaunix.net/uid-20498361-id-4303232.html http://blog.csdn.net/kongqz/article/deta ...
- 一致性 hash 算法( consistent hashing )a
一致性 hash 算法( consistent hashing ) 张亮 consistent hashing 算法早在 1997 年就在论文 Consistent hashing and rando ...
- Ceph剖析:数据分布之CRUSH算法与一致性Hash
作者:吴香伟 发表于 2014/09/05 版权声明:可以任意转载,转载时务必以超链接形式标明文章原始出处和作者信息以及版权声明 数据分布是分布式存储系统的一个重要部分,数据分布算法至少要考虑以下三个 ...
随机推荐
- Python 10 训练模型
原文:https://www.cnblogs.com/denny402/p/7520063.html 原文:https://www.jianshu.com/p/84f72791806f 原文:http ...
- SpringBoot:使用feign调用restful服务时地址栏传参
1.服务提供者(controller层) @GetMapping("/user/{id}") public ApiResult getById(@PathVariable(&quo ...
- Net core学习系列(十)——Net Core配置
一.前言 选项(Options)模式是对配置(Configuration)的功能的延伸.在12章(ASP.NET Core中的配置二)Configuration中有介绍过该功能(绑定到实体类.绑定至对 ...
- Ubuntu16.04.1上搭建分布式的Redis集群,并使用C#操作
为什么要集群: 通常为了,提高网站的响应速度,总是把一些经常用到的数据放到内存中,而不是放到数据库中,Redis是一个很好的Cache工具,当然了还有Memcached,这里只讲Redis.在我们的电 ...
- 大牛总结的MySQL锁优化【转】
MySQL 就是其中之一,它经历了多个版本迭代.数据库锁是 MySQL 数据引擎的一部分,今天我们就一起来学习 MySQL 的数据库锁和它的优化. MySQL 锁分类 当多个事务或者进程访问同一个资源 ...
- android测试和iOS测试的区别
一.常识性区别 二.导航方式 iOS:Tab放在页面底部,不能通过滑动来切换,只能点击.也有放在上面的,也不能滑动,但有些Tab本身可以滑动,比如天猫的.还有新闻类的应用. Android:一般放在页 ...
- docker使用dnnmmp安装gocron
使用dnnmmp安装mysql和phpmyadmin默认使用dnnmmp_default网络,因为在安装其他依赖mysql的应用时,需指定网络 ,同时需指定mysql名称 原命令: docker ru ...
- 在easyui-tabs中的href或 content的多种条件下的不同页面内容和页面地址的赋值?
$('#tt').tabs('add', {.....});中 的 加载内容, 可以用content, 或用 href都是可以的. 虽然它们加载 的方式不一样, 但是 只要是加载进去后, 加载成功后, ...
- [转]vscodesvn安装和使用
原文链接:https://blog.csdn.net/wzh66888/article/details/90145340 1.安装svn插件 2.安装成功后会出现这样的图标 如果没有安装之后不能使用, ...
- mac软件安装 for Mac
Office 2019 for Mac 16.31(191110)官方原版安装包&激活 赠送Office 2016 16.16.16(191111) --------- https://www ...