面试题:说说 Redisson 分布式锁的原理?
Redisson 是一个基于 Redis 的 Java 客户端,它封装了分布式锁的实现,解决了传统 SETNX 等方法的局限性。其核心原理围绕 原子性、安全性 和 自动续期 设计,以...
面试题:Redis Zset 的实现原理是什么?
Redis 的 ZSet(有序集合) 是 Redis 提供的一种高性能数据结构,既能保证元素的 唯一性,又能通过 分数(Score)进行排序。其底层实现结合了 跳表(Skip List) ...
面试题:为什么 Redis Zset 用跳表实现而不是红黑树?B+树?
Redis 的 有序集合(ZSet) 选择使用 跳表(Skip List) 而不是 红黑树(Red-Black Tree) 或 B+树,主要是基于以下多维度的权衡和优化需求。以下是详细分...
面试题:Redisson 看门狗(watch dog)机制了解吗?
Redisson 的 看门狗(Watch Dog)机制 是其分布式锁实现中的核心特性,用于解决分布式锁因业务执行时间过期而导致锁提前释放的问题。以下是对其原理、作用和实现的详细解析: 一、为...
面试题:MySQL 中的数据排序是怎么实现的?
MySQL 中的数据排序主要通过 排序算法 和 索引的有序性 实现,具体逻辑与存储引擎(如 InnoDB)、查询语句、数据量密切相关。以下是其核心实现原理和流程: 一、核心逻辑:...
面试题:MySQL 的 Change Buffer 是什么?它有什么作用?
MySQL 的 Change Buffer 是什么?它有什么作用? 1. 定义与核心作用 Change Buffer 是 MySQL InnoDB 存储引擎 中的一个关键优化机制,主要用于缓存对 非唯一二级索引(如普...
面试题:详细描述一条 SQL 语句在 MySQL 中的执行过程。
一条 SQL 语句在 MySQL 中的执行过程涉及多个层次和组件的协同工作。以下是详细的执行流程,结合 MySQL 的架构(Server 层和存储引擎层)进行说明: 一、执行流程概览 客户端发送请求 连接管理...
面试题:MySQL 的存储引擎有哪些?它们之间有什么区别?
MySQL 的存储引擎是其核心功能之一,不同的存储引擎支持不同的特性、性能优化和适用场景。以下是常见的 MySQL 存储引擎及其区别: 一、常见存储引擎 InnoDB(默认引擎) 特点: 事务支持:支持 ...
面试题:MySQL 的索引类型有哪些?
MySQL 的索引类型可以从多个维度进行分类,以下是常见的索引类型及其特点、适用场景和创建方式的总结: 一、按数据结构分类 B-Tree 索引(默认索引类型) 特点: 基于平衡多路搜索树(B+树)实...
面试题:MySQL InnoDB 引擎中的聚簇索引和非聚簇索引有什么区别?
MySQL InnoDB 引擎中聚簇索引与非聚簇索引的区别 1. 定义与核心特性 特性聚簇索引(Clustered Index)非聚簇索引(Non-Clustered Index / 二级索引)定义数据行的物理存储顺序与索引的逻辑顺序...