排序
面试题:为什么 MySQL 索引用的是 B+ 树而不是红黑树?
MySQL 选择 B+ 树作为索引结构而不是红黑树,主要基于以下几个关键原因: 1. 磁盘 I/O 效率 B+ 树是为磁盘存储系统优化的数据结构: 多路平衡查找树:B+ 树的每个节点可以包含多个键值(通常为...
面试题:Redis 的 hash 是什么?
在 Redis 中,Hash(哈希) 是一种数据结构,它可以存储一个字符串字段和值之间的映射关系。Redis 的 Hash 类似于编程语言中的字典或对象的概念,非常适合用来表示对象。每个 Hash 可以存储多达...
面试题:MySQL 中的索引数量是否越多越好?为什么?
在 MySQL 中,索引数量并不是越多越好。虽然索引可以显著加速查询操作,但过多的索引会带来一系列负面影响,尤其是在写操作性能、存储开销、优化器效率和维护成本等方面。以下是具体原因和优化...
面试题:Redis 中有哪些内存淘汰策略?
Redis 提供了 8 种内存淘汰策略,用于在内存不足时自动删除数据,以腾出空间容纳新数据。这些策略分为 4 类:LRU(最近最少使用)、LFU(最不经常使用)、Random(随机) 和&nbs...
面试题:MySQL 中 InnoDB 存储引擎与 MyISAM 存储引擎的区别是什么?
MySQL中的InnoDB和MyISAM是两种常用的存储引擎,它们各自具有不同的特点和适用场景。以下是这两种存储引擎的主要区别: 事务支持 InnoDB:支持事务处理(ACID兼容),提供提交、回滚和崩溃恢复...
面试题:Redis 集群会出现脑裂问题吗?
Redis 集群确实存在脑裂问题的风险,尤其是在网络分区或主从切换过程中。以下是详细的分析和解决方案: 1. 什么是脑裂问题? 脑裂(Split-Brain) 是分布式系统中的典型故障场景,指由于网...
面试题:Redis 中跳表的实现原理是什么?
在 Redis 中,跳表(Skip List)是一种可以用来实现有序集合(Sorted Set)的数据结构。 虽然 Redis 的有序集合主要使用的是基于跳表和哈希表的混合结构,但跳表是其实现高效范围查询的关键部分...
面试题:Redis 的持久化机制有哪些?
Redis 的持久化机制主要有以下三种方式: 1. RDB(Redis Database) 原理 RDB 是通过 快照(Snapshot) 的方式,将 Redis 内存中的数据在指定时间间隔内持久化到磁盘上,生成一个&nbs...
面试题:如何解决 Redis 中的热点 key 问题?
解决 Redis 中的 热点 Key 问题(即某个 Key 被大量并发访问,导致 Redis 节点负载过高甚至崩溃)是高并发场景下的核心挑战之一。以下是常见的解决方案,结合理论与实际场景的分析: 1. 本...
面试题:你们生产环境的 MySQL 中使用了什么事务隔离级别?为什么?
在生产环境中选择MySQL的事务隔离级别主要取决于应用的具体需求,包括数据一致性、并发性能以及可能出现的并发问题(如脏读、不可重复读和幻读)。 MySQL支持四种标准的事务隔离级别:READ UNCO...