上一篇 <<<Redis集群模式之哨兵模式
下一篇 >>>Linux环境下安装单机Redis
Redis Cluster去中心化分片集群使用Hash卡槽来确定和定位Key的读写位置,最大的优点是有利于Redis动态扩容、缩容,把缓存雪崩数据丢失的风险降到最小。
Cluster集群实现的原理
采用hash槽的概念,预先分配16384个卡槽,相当于是16384个分表,一个卡槽可以存放多个key。
当有读或写的时候,将key进行crc16(key)%16384获取余数,余数就是对应的卡槽,从而将读或写转发到该卡槽的redis节点。
只有主的节点才会分配卡槽,从节点没有卡槽。
Cluster如何实现减少冗余数据
通过卡槽实现,它的作用是决定key存放具体的服务器位置,从而实现均摊存放数据,减少冗余数据。 类似我们在数据库中具体的分表 优点:动态实现扩容和缩容
推荐阅读:
<<<分布式缓存与本地缓存的区别
<<<Ehcache基础知识
<<<SpringBoot整合Ehcache
<<<Redis的5种数据类型
<<<Redis存放实体对象的方式及区别
<<<Redis的应用场景汇总
<<<Redis高效及线程安全的真正原因
<<<Redis为啥要分为16个库
<<<RDB和AOF持久化方式的区别
<<<Redis与数据库的一致性解决方案
<<<SpringBoot整合Redis的注解版本完成数据缓存
<<<Redis的淘汰策略
<<<Redis的事务操作(Mult和Watch)知识点
<<<Redis的过期机制使用场景示例
<<<Redis实现分布式锁的原理分析
<<<Redis分布式锁的实现代码示例
<<<使用Redisson工具实现分布式锁
<<<Redis集群模式之主从复制原理及存在的缺陷
<<<Redis集群模式之哨兵模式
<<<Linux环境下安装单机Redis
<<<Redis Cluster集群环境搭建
<<<Redis Cluster如何动态扩容与缩容
<<<Redis Cluster主从节点自动切换
<<<Redis集群模式的类型和缺陷汇总
<<<Redis缓存的穿透、击穿和雪崩效应
<<<Redis解决穿透击穿问题时使用的布隆过滤器知识点
<<<Redis与MySQL的数据同步解决方案
<<<阿里云的Canal框架实现Redis与Mysql同步原理及代码示例
<<<阿里云的Canal框架配置
<<<Redis官方提出的redlock分布式锁
<<<Redis的调优设置
<<<Redis常见问题汇总