Redis面试题记录

Redis 为什么快?

  1. 纯内存操作:数据都在内存里面,纳秒级别,像mysql读磁盘是毫秒级别,就很慢。
  2. 单线程模型,避免锁竞争:没有多线程的锁、切换等。
  3. IO多路复用:使用select/epoll同时监听多个连接,一个线程实现多并发。
  4. 命令处理简单高效:用的键值模型,底层数据结构简单,命令执行复杂度大多是O(1)或者O(logN)。
  5. 使用C语言实现,效率高。
  6. 使用RESP,网络协议简单,数据包小。

Redis 有哪些常用的数据结构?

字符串(string)、哈希(Hash)、列表(List)、集合(Set)、有序集合(ZSet)。

Redis RDB 和 AOF 持久化的区别,如何选择?

RDB :定时拍快照,全量备份。把内存数据全量保存在.rdb文件,文件小是压缩二进制,恢复速度超级快。如果宕机会丢数据。追求性能,可以接受部分数据丢失。

AOF :记录一条写命令,实时日志 。把所有写命令追加到.aof日志中,不存数据,基本不丢数据,但是存的文件很大,是纯文本。追求数据绝对安全,不丢数据。

最好两个同时开启使用,最稳妥,恢复时使用AOF,保证数据完整。

如何解决缓存击穿、缓存穿透、雪崩问题?

缓存击穿:某个热点key过期了,或大量并发同时请求这个key,导致数据库崩。

解决缓存击穿

  • 添加互斥锁;
  • 热点key设置永不过期;
  • 加逻辑过期和后台定时刷新。

缓存穿透:查不存在的数据,查不到还反复查数据库,大量恶意请求导致DB被打垮。

解决缓存穿透

  • 缓存空值(查不到就存一个空值,设置短暂过期);
  • 使用布隆过滤器;
  • 接口做参数校验、限流、黑名单。

缓存雪崩:大量key同一时间集体过期,或者redis宕机,所有请求同时到数据库。

解决雪崩

  • 过期时间加随机值,避免同时大批量过期;
  • 搭建redis集群,防止单点挂导致的雪崩;
  • 多级缓存;
  • 限流、熔断、降级保护数据库;
  • 互斥锁/队列。
相关推荐
数据知道1 小时前
claw-code 源码分析:OmX `$team` / `$ralph`——把 AI 辅助开发从偶发灵感变成可重复流水线
数据库·人工智能·mysql·ai·claude code·claw code
__土块__2 小时前
大厂后端一面模拟:从线程安全到分布式缓存的连环追问
jvm·redis·mysql·spring·java面试·concurrenthashmap·大厂后端
麦聪聊数据2 小时前
企业数据流通与敏捷API交付实战(六):内部API门户与自助分发机制
数据库·低代码·restful·etl
做个文艺程序员2 小时前
深入 MySQL 内核:MVCC、Buffer Pool 与高并发场景下的极限调优
数据库·mysql·adb
杰克尼2 小时前
redis(day03-优惠券秒杀)
数据库·redis·缓存
七夜zippoe2 小时前
DolphinDB入门:时序数据库的正确打开方式
数据库·struts·时序数据库·工业互联网·dolphindb
数厘3 小时前
2.4MySQL安装配置指南(电商数据分析专用)
数据库·mysql·数据分析
一只小白0003 小时前
数据库对象实例化流程模板 + 常见错误
数据库
一江寒逸3 小时前
零基础从入门到精通MySQL(下篇):精通篇——吃透索引底层、锁机制与性能优化,成为MySQL实战高手
数据库·mysql·性能优化