Redis面试常见问答

**

Redis面试常见问答

1.什么是缓存雪崩?怎么解决?
在这里插入图片描述
通常,我们会使用缓存用于缓冲DB得冲击,如果缓存宕机,所有请求将直接打在DB,造成DB宕机----从而导致整个系统宕机

如何解决呢?
在这里插入图片描述2种策略(同时使用)
1.对缓存做高可用,防止缓存宕机。
2.使用断路器,如果缓存宕机,为了防止系统全部宕机,限制部分流量进入DB,保证部分可用,其余得请求返回短路器得默认值。
2.什么是缓存穿透?怎么解决?
解释 1:缓存查询一个没有的key,同时数据库也没有,如果黑客大量得使用这种方式,那么就会导致DB宕机

解决方案:我们可以使用一个默认值来防止,例如,当访问一个不存在的key,然后再去访问数据库,还是没有,那么就在缓存里放一个占位符,下次来的时候,检查这个占位符,如果发生时占位符,就不去数据库查询了,防止DB宕机.

解释 2:大量请求查询一个刚刚失效的key,导致DB压力倍增,可能导致宕机,但实际上,查询的的都是相同得数据

解决方案:可以在这些请求代码加上双重检查锁。但是那个阶段得请求会变慢。不过总比DB宕机好。

3.什么是缓存并发竞争?怎么解决?

解释:多个客户端写一个key,如果顺序错了,数据就不对了。但是顺序我们无法控制。

解决方案:使用分布式锁,例如zk,同时加入数据得时间戳。同一时刻,只有抢到锁得客户端才能写入,同时,写入时,比较当前数据得时间戳和缓存中数据得时间戳。

4.什么是缓存和数据库双写不一致?怎么解决?

解释:连续写数据库和缓存,但是操作期间,出现并发了,数据不一致了。

通常,更新缓存和数据库有以下几种顺序:

先更新数据库,再更新缓存
先删缓存,再更新数据库
先更新数据库,再删除缓存

三种方式得优劣势来看一下:

先更新数据库,再更新缓存。

这么做的问题是:当有 2 个请求同时更新数据,那么如果不使用分布式锁,将无法控制最后缓存的值到底是多少。也就是并发写的时候有问题。

先删缓存,再更新数据库。

这么做的问题:如果在删除缓存后,有客户端读数据,将可能读到旧数据,并有可能设置到缓存中,导致缓存中的数据一直是老数据。

有 2 种解决方案:

使用“双删”,即删更删,最后一步的删除作为异步操作,就是防止有客户端读取的时候设置了旧值。

使用队列,当这个 key 不存在时,将其放入队列,串行执行,必须等到更新数据库完毕才能读取数据。

总的来讲,比较麻烦。

先更新数据库,再删除缓存

这个实际是常用的方案,但是有很多人不知道,这里介绍一下,这个叫 Cache Aside Pattern,老外发明的。如果先更新数据库,再删除缓存,那么就会出现更新数据库之前有瞬间数据不是很及时。

同时,如果在更新之前,缓存刚好失效了,读客户端有可能读到旧值,然后在写客户端删除结束后再次设置了旧值,非常巧合的情况。

有 2 个前提条件:缓存在写之前的时候失效,同时,在写客户度删除操作结束后,放置旧数据 —— 也就是读比写慢。设置有的写操作还会锁表。

所以,这个很难出现,但是如果出现了怎么办?使用双删!!!记录更新期间有没有客户端读数据库,如果有,在更新完数据库之后,执行延迟删除。

还有一种可能,如果执行更新数据库,准备执行删除缓存时,服务挂了,执行删除失败怎么办???

这就坑了!!!不过可以通过订阅数据库的 binlog 来删除。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一些关于 Redis 运维的常见面试问题及其详细解答: 1. Redis 是什么?它的特点是什么? - Redis(Remote Dictionary Server)是一个开源的内存数据存储系统,也可以用作数据库、缓存和消息队列。 - Redis 的特点包括高性能、支持多种数据结构、丰富的功能(如持久化、发布订阅、事务等)、易于部署和使用。 2. Redis 的持久化机制有哪些?它们之间有什么区别? - Redis 提供了两种持久化机制:RDBRedis Database)和AOF(Append-Only File)。 - RDB 是通过将内存中的数据快照写入磁盘来实现持久化,适用于备份和恢复数据。 - AOF 是通过将写操作追加到一个日志文件中来实现持久化,适用于数据完整性和持久性要求更高的场景。 3. Redis 的主从复制是什么?它的作用是什么? - Redis 的主从复制是指将一个 Redis 服务器作为主节点,其他服务器作为从节点,将主节点上的数据复制到从节点。 - 主从复制的作用包括提高读性能(从节点可以处理读请求)和提供数据冗余和故障转移能力。 4. Redis 的高可用性如何实现? - Redis 可以通过使用主从复制和哨兵机制来实现高可用性。 - 哨兵是一个监控系统,它可以检测主节点的状态,并在主节点宕机时自动将一个从节点升级为新的主节点。 5. Redis 的数据淘汰策略有哪些?它们之间有什么区别? - Redis 的数据淘汰策略包括:noeviction、allkeys-lru、allkeys-random、volatile-lru、volatile-random、volatile-ttl。 - noeviction:不做淘汰,当内存不足时,新写入的数据会导致写操作失败。 - allkeys-lru:从所有键中选择最近最少使用的进行淘汰。 - allkeys-random:随机选择一个键进行淘汰。 - volatile-lru:从设置了过期时间的键中选择最近最少使用的进行淘汰。 - volatile-random:从设置了过期时间的键中随机选择一个进行淘汰。 - volatile-ttl:从设置了过期时间的键中选择剩余时间最短的进行淘汰。 这些是关于 Redis 运维的常见面试问题及其详细解答。在准备面试时,还应该掌握 Redis 的其他方面,如性能调优、监控和故障处理等,以便更好地回答问题和展示你的能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值