Redis集群

一、Redis集群介绍:

由于数据量过大,单个Master复制集难以承担,因此需要对多个复制集进行集群,形成水平国战每个复制集只负责存储整个数据集的一部分,这就是Redis集群,其作用是提供在多个Redis节点间共享数据的程序集;Redis集群是一个提供在多个Redis节点间共享数据的程序集,可以支持多个Master

二、Redis集群的作用:

1.Redis集群支持多个Master,每个Master又可以挂载多个Slave,因此可以做到读写分离、数据的高可用以及海量数据的读写存储操作

2.由于Cluster自带Sentinel的故障转移机制,内置了高可用的支持,无需再去使用哨兵功能

3.客户端与Redis的节点连接,不再需要连接集群中所有的节点,只需要任意连接集群中的一个可用节点即可

4.槽位slot负责分配到各个物理服务节点,由对应的集群来负责维护节点、插和数据之间的关系

三、Redis集群分片以及槽位Slot

1.Redis集群的槽位:

Redis集群没有使用一致性hash,而是引入了哈希槽的概念,有16384个哈希槽,每个key通过CRC16校验后对16384取模来决定放置哪个槽,集群的每个节点复制一部分hash槽

2.Redis集群的分片:

分片是指在使用Redis集群时会将存储的数据分散到多台Redis机器上,集群中的每个Redis实例都被认为是整个数据的一个分片;为了找到给定的key的分片,可以对key进行CRC16算法处理并通过对总分片数量取模,然后使用确定性的哈希函数,这意味着给定的key将多次始终映射到同一个分片,可以推断将来读取特定key的位置

这种结构很容易添加或者删除节点,比如如果我想新添加个节点D,需要从节点A,B,C中得部分槽到D上,如果想移除节点A,需要将A中的槽移到B和C节点上,然后将没有任何槽的A节点从集群中移除即可,由于从一个节点将哈希槽移动到另一个节点并不会停止服务,所以无论添加删除或者改变某个节点的哈希槽的数量都不会造成集群不可用的状态

3.slot槽位映射方法

(1).哈希取余分区:

用户每次读写操作都是根据公式:hash(key) % N个机器台数,计算出哈希值,用来决定数据映射到哪一个节点上;

优点是简单有效,只需要预估好节点,就能保证一段时间的数据支撑,使用Hash算法让固定的一部分请求落到同一台服务器上,这样每台服务器固定处理一部分请求,起到负载均衡和分而治之的作用;

缺点在于规划好的节点后每次数据变动导致节点有变动,映射关系需要重新计算;在服务器个数固定不变时没有问题,如果需要弹性扩容或故障停机的情况下原先的取模公式会发生变化,此时地址经过取余运算的结果将发生很大变化,根据公式获取的服务器也会变得不可控

(2).一致性哈希算法分区:

当服务器个数发生变动时尽量减少影响客户端到服务器的映射关系

a.算法构建一致性哈希环:

一致性哈希算法必然有个hash函数并按照算法产生hash值,这个算法的所有可能哈希值会构成一个全量集,这个集合可以成为一个hash空间,这是一个线性空间,但是在算法中通过适当的逻辑控制使其首尾相连,形成一个环状的空间;

一致性哈希算法也是按照使用取模的方法,是对2^32取模,简单来说一致性Hash算法将整个哈希值空间组织成一个虚拟的圆环,如假设某哈希函数H的值空间为0-2^32-1(即哈希值是一个32位无符号整形),整个哈希环如下图:整个空间按顺时针方向组织,圆环的正上方的点代表0,0点右侧的第一个点代表1,以此类推,2、3、4、……直到2^32-1,也就是说0点左侧的第一个点代表2^32-1, 0和2^32-1在零点中方向重合,我们把这个由2^32个点组成的圆环称为Hash环

b.服务器IP节点映射:

将集群中各个IP节点映射到环上的某一个位置,各个服务器使用Hash进行一个哈希,具体可以选择服务器的IP或主机名作为关键字进行哈希,这样每台机器就能够确定其在哈希环上的位置

c.key落到服务器的落键规则:

需要存储一个kv键值对时,首先计算key的hash值,即计算hash(key),将这个key使用相同的函数Hash计算出哈希值并确定此数据在环上的位置。从此位置沿环顺时针“行走”,第一台遇到的服务器就是其应该定位到的服务器,并将该键值对存储在该节点上。

d.一致性哈希算法的优缺点:

d.1.一致性哈希算法具有容错性:

一般的,在一致性Hash算法中,如果一台服务器不可用,则受影响的数据仅仅是此服务器到其环空间中的前一台服务器(即沿着逆时针方向行走遇到的第一台服务器)之间的数据,其他不受影响。

d.2.一致性哈希算法具有扩展性:

数据量增加了,需要增加一台节点NodeX,X的位置在A和B之间,受到影响的也就是A到X之间的数据,重新把A的数据录入到X上即可,不会导致哈希取余全部数据重新洗牌

d.3.一致性哈希算法存在数据倾斜问题:

一致性Hash算法在服务节点太少时,容易因为节点分布不均而造成数据倾斜,即被缓存的对象大部分集中缓存在某一台服务器上

(3).哈希槽分区算法:

能够均匀解决分配的问题,在数据和节点之间又加入了一层,把这层称为哈希槽,用于管理数据和节点之间的关系,现在就相当于在节点上放的是槽,槽里放的是数据;一个集群只能有16384个槽,编号为0~16383,这些槽会分配给集群中的所有主节点,分配策略没有要求;集群会记录节点和槽的对应关系,解决了节点和槽的关系后需要对key求哈希值,然后对16384取模,余数是多少key就落入到对应的槽中;以槽为单位移动数据,因为槽的数目是固定的,处理起来比较容易,这样数据移动问题就能够得以解决

Redis集群中内置了16384个哈希槽,redis会根据节点数量大致均等的将哈希槽映射到不同的节点。当需要在 Redis 集群中放置一个key-value时,redis先对Key使用crc16算法算出一个结果然后用结果对16384求余数[CRC16(key)%16384],这样每个 key 都会对应一个编号在 0-16383 之间的哈希槽,也就是映射到某个节点上。

为什么redis集群的最大槽数是16384:

4.Redis集群不保证强一致性:

在特定条件下,Redis可能会丢掉一些被系统收到的写入请求命令

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值