数据库-Redis(17)

目录

[81.什么是Redis Cluster?](#81.什么是Redis Cluster?)

82.说说Redis哈希槽的概念?为什么是16384个?

83.Redis集群会有写操作丢失吗?为什么?

84.Redis客户端有哪些?

85.Redis如何做大数据量插入?


81.什么是Redis Cluster?

Redis-Cluster是一种服务器sharding技术,Redis3.0以后版本正式提供支持。

82.说说Redis哈希槽的概念?为什么是16384个?

Redis-Cluster没有使用一致性hash,而是引入了哈希槽的概念。Redis-Cluster中有16384(即2的14次方)个哈希槽,每个key通过CRC16校验后对16383取模来决定放置哪个槽。Cluster中的每个节点负责一部分hash槽(hash slot)。

比如集群中存在三个节点,则我可能存在一种分配如下:

1.节点a包括0-5500号哈希槽;

2.节点b包含5501-11000号哈希槽;

3.节点c包含11001-16384号哈希槽;

为什么是16384个?

在Redis节点发送心跳包时需要把所有的槽放到这个心跳包里,以便让节点直到当前集群信息,16384=16k,在发送心跳包时使用char进行bitmap压缩后是2k(2*8*8 bit)*1024(1k)=16k),也就是说使用2k的空间创建了16k的槽数。

虽然使用CRC16算法最多可以分配65535(2^16-1)个槽位,65535=65k,压缩后就是8k(8*8(8bit)*1024(1k)=65k),也就是说需要需要8k的心跳包,作者认为这样做不太值得;并且一般情况下下一个Redis集群不会有超过1000个Master节点,所以16k的槽位是个比较合适的选择。

83.Redis集群会有写操作丢失吗?为什么?

Redis并不能保证数据强一致性,这意味着在实际中集群在特定的条件下可能会丢失写操作。

84.Redis客户端有哪些?

Redisson,Jedis,Letture等等,官方推荐使用Redisson。

Redisson是一个高级的分布式协调Redis客服端,能帮助用户在分布式环境中轻松实现一些Java对象。

85.Redis如何做大数据量插入?

Redis2.6开始redis-cli支持一种新的被称为pipe mode的新模式用于执行大量数据插入工作。

相关推荐
马克Markorg3 小时前
常见的向量数据库和具有向量数据库能力的数据库
数据库
Coder_Boy_5 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
helloworldandy5 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
数据知道7 小时前
PostgreSQL 故障排查:如何找出数据库中最耗时的 SQL 语句
数据库·sql·postgresql
qq_12498707537 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
枷锁—sha7 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
Coder_Boy_7 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Gain_chance7 小时前
35-学习笔记尚硅谷数仓搭建-DWS层最近n日汇总表及历史至今汇总表建表语句
数据库·数据仓库·hive·笔记·学习
此生只爱蛋8 小时前
【Redis】主从复制
数据库·redis
马猴烧酒.8 小时前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库