Redis面试常见问题有哪些

技术Redis面试常见问题有哪些本篇内容主要讲解“Redis面试常见问题有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Redis面试常见问题有哪些”吧!1. 什么是缓存

本文主要讲解“Redis面试中有哪些常见问题”,感兴趣的朋友不妨看看。本文介绍的方法简单、快速、实用。让边肖带你学习“Redis面试中有哪些常见问题”!

1. 什么是缓存雪崩?怎么解决?

Redis面试常见问题有哪些

通常,我们会使用缓存来缓冲对数据库的影响。如果缓存宕机,所有请求都会直接命中数据库,导致数据库宕机;mdash从而导致整个系统停机。

如何解决呢?

Redis面试常见问题有哪些

2 种策略(同时使用):

使缓存高度可用,以防止缓存停机。

使用断路器。如果缓存宕机,为了防止系统完全宕机,请将一些流量限制到DB中,确保一些流量可用,并将其余流量恢复到断路器的默认值。

2. 什么是缓存穿透?怎么解决?

解释 1:缓存查询一个不可用的密钥,同时也没有数据库。如果黑客广泛使用这种方法,将导致数据库宕机。

解决方案:我们可以使用默认值来防止它。例如,当访问一个不存在的键,然后访问数据库,但它仍然不存在,然后在缓存中放一个占位符,下次检查占位符。如果发生占位符,它不会进入数据库查询以防止数据库崩溃。

大量的解释 2:请求查询一个刚刚失败的键,导致DB的压力翻倍,可能导致宕机,但实际上所有的查询都是相同的数据。

解决方案:可以在这些请求代码中添加双重检查锁。但是在那个阶段的请求会变慢。但总比DB停机要好。

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

解释:多个客户写一把钥匙。如果顺序错了,数据也会错。但是我们不能控制顺序。

使用解决方案:分布式锁,如zk,并添加数据的时间戳。同时,只有抢到锁的客户端才能写。同时,在写入时,将当前数据的时间戳与缓存中的数据的时间戳进行比较。

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

说明:数据库和缓存是连续写入的,但是在操作过程中出现并发,数据不一致。

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

首先更新数据库,然后更新缓存。

首先删除缓存,然后更新数据库。

首先更新数据库,然后删除缓存。

看看这三种方式的优缺点:

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

问题是:当同时有两个更新数据的请求时,如果不使用分布式锁,将无法控制最后一个缓存的值。也就是并发写的时候有问题。

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

问题:如果客户端在删除缓存后读取数据,可能会读取旧数据,旧数据可能会被设置到缓存中,导致缓存中的数据始终是旧数据。

有2种解决方案:

使用“Double Delete”,即删除和删除,删除的最后一步是异步操作,即防止客户端读取旧值时设置旧值。

使用队列。当这个键不存在时,将它放入队列并连续执行。在数据库更新之前,您不能读取数据。

总的来说比较麻烦。

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

其实这个方案很常见,只是很多人不知道。这里简单介绍一下。这个方案叫做缓存备用模式,是外国人发明的。如果先更新数据库,再删除缓存,在更新数据库之前会有即时数据,不是很及时。

同时,如果更新前缓存刚好失效,读取客户端可能会读取旧值,然后在写入客户端删除后再次设置旧值,这是非常巧合的。

有两个前提条件:写前缓存会失效,同时写定制删除操作后会放置旧数据mdashmdash也就是说,阅读比写作慢。一些写操作也会锁定表。

因此,这很难出现,但如果出现了呢?使用双重删除!记录客户端在更新期间是否读取数据库,如果是,则在更新数据库后执行延迟删除。

至此,相信大家对“Redis面试中的常见问题有哪些”有了更深的理解,让我们一起来实践吧!这是网站。更多相关内容,可以去相关渠道查询,关注我们,继续学习!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/101150.html

(0)

相关推荐

  • 如何把word压缩小一点

    技术如何把word压缩小一点这篇文章给大家分享的是有关如何把word压缩小一点的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。  使用工具:迅捷压缩  工具介绍:  迅捷压缩软件是一款集图片压缩

    攻略 2021年10月26日
  • 线性回归理解和应用例子

    技术线性回归理解和应用例子 线性回归理解和应用例子HaHa,没错又是作业...
    理解:
    线性回归是利用数理统计中回归分析,来确定两种或两种以上变量间相互依赖的定量关系的一种统计分析方法。
    这句话里的“相

    礼包 2021年11月22日
  • Java中混淆技术有几种

    技术Java中混淆技术有几种这篇文章给大家分享的是有关Java中混淆技术有几种的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。到目前为止,对于Java程序的保护,混淆技术还是最基本的保护方法。J

    攻略 2021年12月8日
  • ajax技术的用法(ajax技术怎么用)

    技术Ajax技术怎么用这篇文章主要介绍了Ajax技术怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 ajax的作用有:1

    攻略 2021年12月17日
  • 答复的英文,“请尽快回复”用英文该怎样说

    技术答复的英文,“请尽快回复”用英文该怎样说“请尽快回复”的英文答复的英文:Please reply as soon as possible.reply 读法 英 [rɪplaɪ] 美 [rɪplai]
    1、作不及物

    生活 2021年10月19日
  • JVM字符串常量池及String的intern方法是什么样的

    技术JVM字符串常量池及String的intern方法是什么样的这篇文章给大家介绍JVM字符串常量池及String的intern方法是什么样的,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。关于字符串

    攻略 2021年10月23日