Redis分布式

算法原理

举个例子,有若干个redis服务,有一个文件,那么这个文件放在哪呢?通常来说先把这个文件进行哈希,然后用redis个数进行取模,hash(file) % num,余数就是对应的服务器编号。

假如有4个redis节点,20个数据,根据上面的算法,redis1上存1,2上存2,以此类推。假如节点现在要扩展,变成5个节点,跟4个节点位置没有发生变化的元素是:redis1-1,redis2-2,redis3-3,redis0-20,那么命中率就是4/20=20%。

接下来说一下Consistent hashing(一致性算法),例如有3个节点,4个对象,通过hash函数计算出hash的值key,那么每一个都会落在对应hash环的位置上,接下来顺时针走,那么key1就会存在cacheA上,key2存在cacheC上,以此类推。

 那么如果我要去掉一个节点B,那么受影响的也只有存在B中的元素key4,key4根据一致性算法会自动找到C并存进去。

如果添加一个节点,也只是影响一部分元素而已。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值