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)

相关推荐

  • 彳怎么读,“彳”“亍”这俩字念什么啊

    技术彳怎么读,“彳”“亍”这俩字念什么啊拼音:chì, 笔顺:332 五笔编码:ttth 【动】(象形彳怎么读。小篆字字形象“行”,象纵横相交的十字路。“彳”是汉字部首之一,习惯上称为双人旁。从“彳”的字多与行走、行为和

    生活 2021年10月21日
  • C#操作Excel实现的实例分析

    技术C#操作Excel实现的实例分析C#操作Excel实现的实例分析,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。C#操作Excel是怎么样执行的呢?我们在

    攻略 2021年11月24日
  • consumer自带函数式接口(console接口是常用接口吗)

    技术基于Consumer接口、Predicate接口初使用是怎样的这篇文章将为大家详细讲解有关基于Consumer接口、Predicate接口初使用是怎样的,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这

    攻略 2021年12月20日
  • mybatis的使用步骤

    技术mybatis的使用步骤 mybatis的使用步骤1.什么是mybatisMyBatis 是一款优秀的持久层框架,它支持自定义 SQL、存储过程以及高级映射。MyBatis 免除了几乎所有的 JDB

    礼包 2021年11月19日
  • mybatis的sql语句如何防止注入(mybatis的sql语句如何预防注入)

    技术mybatis使用${}时sql注入的问题怎么解决这篇文章给大家介绍mybatis使用${}时sql注入的问题怎么解决,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。mybatis使用${}时sq

    攻略 2021年12月16日
  • Oracle中如何解决ORA-01555错误

    技术Oracle中如何解决ORA-01555错误这篇文章给大家分享的是有关Oracle中如何解决ORA-01555错误的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。11.6 ORA-01555

    攻略 2021年11月20日