排序
面试题:如何使用 Redis 统计大量用户唯一访问量(UV)?
在互联网应用中,统计大量用户的唯一访问量(UV) 是一个常见且重要的需求。Redis 提供了多种高效的数据结构和算法来实现这一目标,以下是常见的几种方法及其适用场景: 1. 使用 Set 数据...
面试题:为什么 Redis Zset 用跳表实现而不是红黑树?B+树?
Redis 的 有序集合(ZSet) 选择使用 跳表(Skip List) 而不是 红黑树(Red-Black Tree) 或 B+树,主要是基于以下多维度的权衡和优化需求。以下是详细分...
面试题:Redis 集群会出现脑裂问题吗?
Redis 集群确实存在脑裂问题的风险,尤其是在网络分区或主从切换过程中。以下是详细的分析和解决方案: 1. 什么是脑裂问题? 脑裂(Split-Brain) 是分布式系统中的典型故障场景,指由于网...
面试题:Redis 中的 Ziplist 和 Quicklist 数据结构的特点是什么?
在 Redis 中,ziplist 和 quicklist 是用于实现某些数据结构(如列表和哈希表)的底层存储机制。它们各自具有独特的特点和适用场景。 Ziplist Ziplist 是一种紧凑的数据结...
面试题:Redis 和 Memcached 有哪些区别?
Redis 和 Memcached 都是高性能的内存键值存储系统,但它们在功能、性能和使用场景上存在一些关键差异。以下是它们的主要区别: 一、数据类型支持 Redis:支持多种数据结构,包括字符串(String...
面试题:如何使用 Redis 快速实现布隆过滤器?
布隆过滤器(Bloom Filter)是一种空间效率非常高的概率型数据结构,主要用于判断一个元素是否在一个集合中。 它的优点是可以用很小的内存代价来表示很大的集合,并且插入和查询的时间复杂度都...
面试题:Redis Zset 的实现原理是什么?
Redis 的 ZSet(有序集合) 是 Redis 提供的一种高性能数据结构,既能保证元素的 唯一性,又能通过 分数(Score)进行排序。其底层实现结合了 跳表(Skip List) ...
面试题:Redis 的哨兵机制是什么?
Redis 的 哨兵机制(Sentinel) 是 Redis 的高可用性解决方案,用于监控主从节点的状态,并在主节点发生故障时自动进行故障转移,确保服务的持续可用性。以下是对其核心原理和功能的...
面试题:如何在 Redis 中实现队列和栈数据结构?
在 Redis 中,可以通过 List 数据结构 实现队列(FIFO)和栈(LIFO)。以下是具体的实现方法和注意事项: 1. 队列(FIFO) 实现原理:Redis 的 List 是一个双向链表,可以通过 L...
面试题:Redis 的 hash 是什么?
在 Redis 中,Hash(哈希) 是一种数据结构,它可以存储一个字符串字段和值之间的映射关系。Redis 的 Hash 类似于编程语言中的字典或对象的概念,非常适合用来表示对象。每个 Hash 可以存储多达...