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集群,防止单点挂导致的雪崩;
  • 多级缓存;
  • 限流、熔断、降级保护数据库;
  • 互斥锁/队列。
相关推荐
SelectDB18 小时前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶19 小时前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵1 天前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
Nturmoils1 天前
WHERE 条件别凭习惯写,常用查询先跑一遍
数据库
云技纵横1 天前
一个 @Async 让循环依赖暴雷:Spring 代理的暗坑
redis
Databend2 天前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent
犯困蛋挞yy2 天前
用Claude快速解决Redis代码报错反复无解的问题
redis
小七-七牛开发者3 天前
TokenPilot:让 LLM Agent 长会话成本降 60%+ 的上下文管理
缓存·agent·token·context·上下文·推理成本
ClouGence3 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将3 天前
从零实现数据库(2)——HashIndex + IndexManager
数据库