Redis 分布式锁进阶第29篇
一、前言经过前面七十五篇内容我们已经完整掌握 Redis 分布式锁从底层原理、各类锁实现、生产踩坑、运维监控、跨技术栈对比全体系知识。在求职面试、技术答辩、代码评审场景中分布式锁是后端、架构岗必考重难点。 本篇分为三大模块经典面试真题由浅入深、Redisson 源码高频考点、全网通用认知误区与错误写法每道题目配套标准答案、得分要点、拓展追问同时区分初级、中级、高级面试难度。技术栈课程二、入门级面试题初级开发 / 基础面试1. 为什么需要分布式锁单机锁为什么不行标准回答单机环境下synchronized、ReentrantLock等本地锁仅能控制单 JVM 内线程互斥。在微服务、集群部署、多实例架构中同一个服务会部署多个节点本地锁无法跨实例生效会导致并发问题因此必须使用分布式锁实现跨进程、跨机器的资源互斥。得分要点点明本地锁作用范围 集群部署场景缺陷 分布式锁核心目标。2. 基于 String 类型实现 Redis 分布式锁命令是什么存在什么问题标准回答防止客户端服务宕机、网络异常、程序卡死等场景下锁无法主动释放造成永久死锁后续所有线程无法获取锁服务彻底阻塞。拓展追问过期时间设置太长 / 太短分别有什么问题太短业务未执行完成锁提前释放锁失效太长出现死锁后资源长时间无法释放服务吞吐量严重下降。三、进阶级面试题中级开发 / 业务架构面试1. Redis 基础锁为什么要用 Lua 脚本多条普通命令不行吗标准回答Redis 单条命令具备原子性但多条命令组合不保证原子性。高并发场景下多条命令之间会被其他请求插队引发数据错乱。 Lua 脚本会将多条指令封装为一个整体Redis 服务端一次性执行完毕中间不会切换执行其他客户端命令保证加锁、重入、解锁全流程原子性