news 2026/5/16 4:38:07

redis数据分片算法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
redis数据分片算法

1.hash取余算法

设有N个分⽚,使⽤[0,N-1]这样序号进⾏编号.

针对某个给定的key,先计算hash值,再把得到的结果%N,得到的结果即为分⽚编号.

举例:N为3.给定key为hello,对hello计算hash值(⽐如使⽤md5算法),得到的结果为bc4b2a76b9719d91 ,再把这个结果%3,结果为0,那么就把hello这个key放到0号分⽚上.

优点:简单高效,数据分配均匀

缺点:扩容后需要大量的数据迁移

2.一致性hash算法

一致性Hash算法也是使用取模的方法,只是1.hash取余算法是对服务器的数量进行取模,而一致性Hash算法是对2^ 32-1取模,简单来说,一致性Hash算法将整个Hash值控件组织成一个虚拟的圆环,如假设某哈希函数H的值空间为0-2^32-1取模(即哈希值是一个32位无符号整型)

整个空间按顺时针方向组织,圆环的正上方的点代表0,0点右侧的第一个点代表1,以此类推,2、3、4、5、6……直到2^ 32-1,也就是说0点左侧的第一个点代表2^ 32-1, 0和2^ 32-1在零点中方向重合,我们把这个由2^32个点组成的圆环称为Hash环。

下一步将各个服务器使用Hash进行一个哈希,具体可以选择服务器的主机名(考虑到ip变动,不要使用ip)作为关键字进行哈希,这样每台机器就能确定其在哈希环上的位置,这里假设将上文中三个master节点的IP地址哈希后在环空间的位置如下:

优点:⼤⼤降低了扩容时数据搬运的规模,提⾼了扩容操作的效率.

缺点:数据分配不均匀(有的多有的少,数据倾斜).

3.hash槽分区算法

1. 哈希槽的概念

Redis集群使用16384个哈希槽来分散键空间。这意味着集群中的每个键都通过计算其哈希值并被映射到这16384个槽中的一个。

2. 哈希槽的分配

在Redis集群中,每个节点负责一部分哈希槽。例如,一个有5个节点的集群可能会将哈希槽平均分配给这5个节点,每个节点负责3276个哈希槽(16384 / 5 = 3276)。

3. 哈希槽的计算

当Redis需要确定一个键应该被存储在哪个节点时,它会使用以下步骤:

  1. 计算键的哈希值‌:使用SHA1哈希函数计算键的哈希值。例如,如果键是"mykey",则其哈希值可以通过SHA1(mykey)计算得到。

  2. 取模运算‌:将得到的哈希值对16384取模(即哈希值 % 16384),以得到该键应该被映射到的哈希槽编号。

    pythonCopyCodehash_slot=hash_value%16384
  3. 查找节点‌:根据得到的哈希槽编号,查找该槽被分配到的节点。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/9 3:47:23

微信小程序接入大模型实战 5:周公解梦 潜意识分析(含代码)

引言本文将介绍如何利用大语言模型(LLM)的深度语义理解能力,结合 Stable Diffusion (SD) 或 Midjourney 的图像生成能力,构建一个“AI 周公解梦 & 潜意识分析”小程序。从技术视角看,解梦并不是玄学预测&#xff0…

作者头像 李华
网站建设 2026/5/15 18:23:26

光伏预测翻车实录:当传统LSTM被群殴时到底发生了什么

LSTM,CNN-LSTM,PSO-LSTM,PSO-CNN-LSTM做光伏功率预测,对比各种算法的误差评价指标。 LSTM预测结果评价指标: RMSE 8.2496 MSE 68.0566 MAE 5.1832 MAPE 0.29202 CNN-LSTM预测结果评价指标: RMSE 0.9…

作者头像 李华
网站建设 2026/5/9 13:10:05

Emby美化插件完整指南:打造专属影音中心的最佳方案

厌倦了Emby千篇一律的默认界面?想要打造专属的个性化影音中心却不知从何下手?这款Emby美化插件就是为你量身定制的界面改造神器!无需任何编程基础,新手也能轻松上手,让你的Emby焕然一新。 【免费下载链接】emby-crx Em…

作者头像 李华
网站建设 2026/5/15 20:29:15

JSON 到底是什么?2025 年最全数据格式“避坑”指南

在当今的互联网世界,如果说 TCP/IP 是铺路石,那么 JSON 就是上面跑的“通用货币”。 无论你是做前端、后端,还是搞大数据、AI,只要涉及数据交换,就绕不开 JSON (JavaScript Object Notation)。它以“轻量级、易读、通用…

作者头像 李华
网站建设 2026/5/9 4:50:13

抛弃笨重虚拟机!MSYS2如何让你在Windows下获得Linux式开发快感

一位开发者删除了电脑上安装了多年的Cygwin,转向一个名为MSYS2的新工具,发现编译速度显著提升,中文支持也更好了。这款工具到底藏着什么秘密? 几年前,Windows开发者的世界还被分为两个阵营:要么完全妥协于W…

作者头像 李华