【redis】一致性哈希算法
大家好,又见面了,我是你们的朋友全栈君。
前言
这周复习redis,被集群和分布式搞得头大,也接触到一致性哈希算法, 因此博主进行了一定得学习,故,写下这篇文章。
一、普通哈希算法
普通得哈希算法是对服务器得数量进行一定得取模预算得出,常见得公式如下:
index = hash(key)%N
N就是服务器得数量。
我们可以想象到,如果服务器数量改变,那么index也会进行改变。例如: 一台服务器宕机,服务里器的数据暂时丢失(系统会进行一定的备份,用户发送的请求经过哈希运算后,因为N的改变,会访问其他的服务器,但是该台服务器还没有拷贝过来宕机的数据.这个时候就会发生问题。如果服务器作为缓存使用,那么大量的数据,会造成缓存击穿。
由于以上问题,我们引入一致性哈希算法。
二、一致性哈希算法
一致性哈希算法的出现,避免了大量数据的迁移(交普通哈希算法而言),解决了普通哈希算法取模动态调整带来的全量数据的变动。
1.一致性哈希算法的原理
一致性哈希算法避免了N的变动,所以说N是固定的,这个N就是2^32次方。 一般我们将这些数字想象成一个闭合的环。
这样落到环上的机器,负责管理一个范围,当某台机器宕机的时候,仅仅是这个范围内的数据不可用,不会造成因为N的改变,再次重新分配的情况。
2 缺点 一致性哈希算法也是有缺点的,就是数据落到每台机器上的概率不同,可能会出现数据分配不均匀的情况。造成某台服务器压力增大。
3.解决
加入虚拟节点,本来一个数据库仅对应一个节点,但是现在将数据库对应多个节点,并将这些节点分布在环上。保证每台服务器上的数据均匀分布。
总结: 本文是博主自己的理解,如有错误。欢迎指出。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/164581.html原文链接:https://javaforall.cn
相关文章
- Redis实现流量控制的技术实践(redis流量控制)
- 利用Redis实现一致性哈希的技术实现(redis实现一致性哈希)
- 如何开启Redis控制台(怎么打开redis控制台)
- 查看远程Redis简单而又实用的方法(查看远程redis)
- Redis实现本地数据的一致性缓存(本地缓存redis一致性)
- 推崇点赞系统架构基于Redis技术(点赞系统设计redis)
- 存储有用信息Redis之路(什么信息放在redis)
- 三节点Redis实现高可用架构(三节点redis)
- 性探索如何实现MySQL与Redis间的一致性(如何实现数据库和redis一致)
- 如何安全有效地保存Redis数据(如何保存redis数据)
- 使用Redis实现数据去重算法(使用redis对数据去重)
- 利用多线程技术实现高效的redis计数器(多线程redis计数器)
- 复制Redis队列双保险保障数据安全(复制redis队列)
- Redis的高频率访问获取更好的性能(redis 频繁访问)
- Redis集群设计构建高可用的系统(redis集群部署高可用)
- 建立Redis集群槽算法实战(redis集群槽算法)
- 数据一致性解决Redis集群保证数据一致性的方法(redis集群怎么保证)
- 保障Redis集群值的一致性(redis集群值一致)
- 基于Redis集群的一致性方案研究(redis集群一致性方案)
- Redis中的主节点选举算法研究(redis选举主节点算法)
- 基于Redis的路由算法优化实现(redis路由算法)
- Redis超时算法有效解决资源管理问题(redis超时算法)
- Redis缩小存储空间,提升存储性能(redis规格是什么)
- Redis实现设计评论回复的研究(redis设计评论回复)
- Redis优化轻松挑战负载平衡算法(redis 负载算法)