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集群,防止单点挂导致的雪崩;
  • 多级缓存;
  • 限流、熔断、降级保护数据库;
  • 互斥锁/队列。
相关推荐
苍煜6 分钟前
慢SQL优化实战教学
java·数据库·sql
zhaoyong22244 分钟前
MySQL 存储过程中字符集与排序规则不匹配导致查询性能下降的解决方案
jvm·数据库·python
sinat_383437361 小时前
golang如何从Python转型Go开发_golang从Python转型Go开发攻略
jvm·数据库·python
远洪1 小时前
claude code 国内安装使用
数据库·mysql
雨辰AI1 小时前
SpringBoot3 + 人大金仓 V9 微服务监控实战|Prometheus+Grafana+SkyWalking 全链路监控
数据库·后端·微服务·grafana·prometheus·skywalking
二哈赛车手1 小时前
新人笔记---ES和kibana启动问题以及一些常用的linux的错误排查方法,以及ES,数据库泄密解决方案[超详细]
java·linux·数据库·spring boot·笔记·elasticsearch
myrh pdmd1 小时前
maven导入spring框架
数据库·spring·maven
爬山算法1 小时前
MongoDB(118)如何在升级过程中进行数据备份?
数据库·mongodb·oracle
千月落2 小时前
Redis数据迁移
数据库·redis·缓存
小编码上说3 小时前
LSH(局部敏感哈希)分桶,海量数据下的相似性搜索解决方案
java·spring boot·缓存·langchain4j·lsh·局部敏感哈希·ai调用优化