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)

相关推荐

  • WiFi攻击方式有哪些

    技术WiFi攻击方式有哪些这篇文章给大家分享的是有关WiFi攻击方式有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1. 伪造MAC地址很多时候开放网络的身份验证往往就是通过上网设备的MA

    攻略 2021年11月20日
  • spark运行机制

    技术spark运行机制 spark运行机制构建DAG(Driver 端完成)
    使用算子操作 RDD 进行各种 Transformation 操作,最后通过 Action 操作触发 Spark 作业运行。

    礼包 2021年11月1日
  • 光影精灵,光影精灵和暗影精灵的区别是什么

    技术光影精灵,光影精灵和暗影精灵的区别是什么区别1光影精灵:定位首先,光影精灵5和暗影精灵5最直观的区别就是两者的设计风格完全不同,这个不需要什么分析,也不需要懂产品,只要是有认知能力的人看到图片都会得出这样的结论。两者

    生活 2021年10月22日
  • 怎么引用html绝对路径与相对路径

    技术怎么引用html绝对路径与相对路径本篇内容介绍了“怎么引用html绝对路径与相对路径”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,

    攻略 2021年11月6日
  • 战时管制是指,什么叫战时状态战时措施

    技术战时管制是指,什么叫战时状态战时措施它是指当国家安全受到严重威胁时,将军队处于最高级的备战准备,并向全国发布战争动员令的一种战斗紧张形势战时管制是指。交战国之间的敌对状态。一旦进入战争状态,交战国之间的外交关系、经济

    生活 2021年10月29日
  • Oracle数据库标准的SYSAUX表空间清理方法是什么

    技术Oracle数据库标准的SYSAUX表空间清理方法是什么这篇文章将为大家详细讲解有关Oracle数据库标准的SYSAUX表空间清理方法是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相

    攻略 2021年11月29日