当前位置:首页 > 服务端 > 2022年Redis最新面试题第6篇

2022年Redis最新面试题第6篇

2022年09月16日 16:50:56服务端6

最近整理一份关于Redis常见面试题的,也会根据自己的经验, 标注一些出现的概率,最高5颗★出现的概率最高。比如这样:

Redis 最适合的场景, 可以简单的说说吗?
出现概率: ★★★★

 
整体目录大概如下:

目录

  • 一、Redis基础知识

    • 1、什么是 Redis, 有哪些优缺点?
    • 2、Redis 最适合的场景, 可以简单的说说吗?
    • 3、Redis 相比 Memcached 有哪些优势?
    • 4、一个字符串类型的值能存储最大容量是多少?
    • 5、Redis 读写分离
  • 二、数据结构

    • 1、Redis的数据类型有哪些?
    • 2、说说 Redis 哈希槽的概念?
    • 3、Hash如何实现O(1)的查询和设置速度, 以及扩容原理
    • 4、布隆过滤器
  • 三、事务

    • 1、怎么理解 Redis 事务?
    • 2、Redis事务执行过程
    • 3、Redis事务的一些使用场景
    • 4、Redis事务与Redis pipeline的区别
    • 5、集群模式下Redis事务如何保证原子性
  • 四、Redis数据持久化

    • 1、为什么 Redis 需要把所有数据放到内存中?
    • 2、Redis如何做持久化的?
    • 3、Redis key 的过期时间和永久有效分别怎么设置?
  • 五、Redis集群

    • 1、Redis 是单进程单线程的?
    • 2、是否使用过 Redis 集群,集群的原理是什么?
    • 3、可以简单说说你对Redis Sentinel的理解
    • 4、Redis Sentinal和Redis Cluster的区别
    • 5、Redis 的同步机制了解么?
    • 6、Redis 集群最大节点个数是多少?
  • 六、Redis淘汰策略

    • 1、Redis过期键的删除策略?
    • 2、你可以简单聊聊Redis内存淘汰机制(回收策略)
  • 七、Redis分布式锁

    • 1、你知道实现实现分布式锁有哪些方案?
  • 八、Redis缓存问题

    • 1、Redis缓存雪崩
    • 2、Redis缓存击穿
    • 3、Redis缓存穿透
    • 4、缓存预热
    • 5、缓存降级
  • 九、运维和部署

    • 1、Redis 如何设置密码及验证密码?
    • 2、Redis 如何做内存优化?



 

一般来讲在面试当中, 关于Redis相关的面试题频率出现比较高的几个关键词是适合哪些场景、数据结构、hash实现原理和如何扩容、如何做持久化、关系型数据库和非关系数据库对比等等。 把这几个点问完基本也差不多10~20分钟了(一般一轮面试1小时左右), 基本这些可以让面试官对你的Redis知识有一定的了解了。

 

也欢迎关注我的公众号: 漫步coding。 一起交流, 在coding的世界里漫步, 回复: redis, 免费获取最新Redis面试题(含答案)。

2022年Redis最新面试题第6篇 _ JavaClub全栈架构师技术笔记

希望这篇文章可以帮助大家, 也希望大家都能找到的好工作。

 

也可以在线看我的博客, 界面如下:

2022年Redis最新面试题第6篇 _ JavaClub全栈架构师技术笔记

 

 

概要

  • Redis过期键的删除策略?

  • 你可以简单聊聊Redis内存淘汰机制(回收策略)

Redis 过期键的删除策略?

出现概率: ★★★★

Redis过期键的删除策略是:定期删除+惰性删除。

2022年Redis最新面试题第6篇 _ JavaClub全栈架构师技术笔记

1)、关于定期删除, Redis默认会每隔100ms就随机选取一些已经过期了的key,检查其是否过期,如果已经过期就删除。

不过假设Redis里放了100w个key,而且都设置了过期时间,你每隔几百毫秒,就检查100w个key,那 Redis基本上就卡死了,cpu负载也会很高的,基本都消耗在检查过期key上了。

注意,这里可不是每隔100ms就遍历所有的设置过期时间的key,那样就是一场性能上的灾难。实际情况是每次随机选取一些key进行检查和删除的。

但因为随机会带来不确定性,可能会导致很多过期key到了时间并没有被删除掉,那应该怎么办呢?所以就需要惰性删除了

关于定期删除源码解析:每当 Redis 服务器的周期性操作 redis.c/serverCron 函数执行时,redis.c/activeExpireCycle 会被调用。
activeExpireCycle 函数在规定的时间内,分多次遍历服务器中的各个数据库,从数据库的 expires 字典中随机检查一部分键的过期时间,并删除其中的过期键。

current_db 记录当前检查的数据库,如果函数 activeExpireCycle 当前正在处理 2 号数据库,时间超限,返回后,下次检查时,会从 3 号数据库开始检查。所有数据库检查一遍后,current_db 重置为 0,然后再次开始一轮的检查工作。

2)、关于惰性删除, 当用户获取某个key的时候,Redis会检查一下这个key是不是设置了过期时间, 并且是否过期了?如果过期了此时就会删除,不会给用户返回任何东西。

惰性删除有一个问题, 依赖用户的主动调用,那如果一些用户就长时间没有访问怎么办, 会导致大量过期 key堆积在内存里,进而导致Redis 内存块耗尽了,咋整?

答案就是:触发Redis内存淘汰机制。(下面会讲到)

你可以简单聊聊Redis内存淘汰机制(回收策略)

出现概率: ★★★★

1)、Redis内存淘汰机制有以下几个:

  • noeviction: 当内存不足以容纳新写入数据时,新写入操作会报错。(这个有点过于暴力, 不推荐)

  • allkeys-lru:当内存不足以容纳新写入数据时,在键空间中,移除最近最少使用的 key(这个是最常用的)。

  • allkeys-random:当内存不足以容纳新写入数据时,在键空间中,随机移除某个 key。

  • volatile-lru:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,移除最近最少使用的 key(这个一般不太合适)。

  • volatile-random:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,随机移除某个 key。

  • volatile-ttl:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,有更早过期时间的 key 优先移除。

2)、Redis默认的过期策略是noeviction, 最暴力那个, 如果内存满了那就是一场“华丽”的故事了。😂

127.0.0.1:6379> config get maxmemory-policy
1) "maxmemory-policy"
2) "noeviction"
127.0.0.1:6379>

2022年Redis最新面试题第6篇 _ JavaClub全栈架构师技术笔记

3)、redis.conf 中的过期淘汰配置如下:

# MAXMEMORY POLICY: how Redis will select what to remove when maxmemory
# is reached. You can select among five behaviors:
#最大内存策略:当到达最大使用内存时,你可以在下面5种行为中选择,Redis如何选择淘汰数据库键

#当内存不足以容纳新写入数据时

# volatile-lru -> remove the key with an expire set using an LRU algorithm
# volatile-lru :在设置了过期时间的键空间中,移除最近最少使用的key。这种情况一般是把 redis 既当缓存,又做持久化存储的时候才用。

# allkeys-lru -> remove any key according to the LRU algorithm
# allkeys-lru :移除最近最少使用的key (推荐)

# volatile-random -> remove a random key with an expire set
# volatile-random :在设置了过期时间的键空间中,随机移除一个键,不推荐

# allkeys-random -> remove a random key, any key
# allkeys-random :直接在键空间中随机移除一个键,弄啥叻

# volatile-ttl -> remove the key with the nearest expire time (minor TTL)
# volatile-ttl :在设置了过期时间的键空间中,有更早过期时间的key优先移除 不推荐

# noeviction -> don't expire at all, just return an error on write operations
# noeviction :不做过键处理,只返回一个写操作错误。不推荐

# Note: with any of the above policies, Redis will return an error on write
# operations, when there are no suitable keys for eviction.
# 上面所有的策略下,在没有合适的淘汰删除的键时,执行写操作时,Redis 会返回一个错误。下面是写入命令:
# At the date of writing these commands are: set setnx setex append
# incr decr rpush lpush rpushx lpushx linsert lset rpoplpush sadd
# sinter sinterstore sunion sunionstore sdiff sdiffstore zadd zincrby
# zunionstore zinterstore hset hsetnx hmset hincrby incrby decrby
# getset mset msetnx exec sort

# 过期策略默认是:
# The default is:
# maxmemory-policy noeviction

 

也欢迎关注我的公众号: 漫步coding。一起交流, 在coding的世界里漫步,     回复: redis, 免费获取最新Redis面试题(含答案)。

 

作者:漫步coding
来源链接:https://www.cnblogs.com/codeguide/p/16196879.html

版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。


本文链接:https://www.javaclub.cn/server/42038.html

标签: Redis面试题
分享给朋友:

“2022年Redis最新面试题第6篇” 的相关文章

Redis面试题整理(有pdf版)

1、什么是 Redis?简述它的优缺点? Redis 的全称是:Remote Dictionary.Server,本质上是一个 Key-Value 类型的内存数据库,很像memcached,整个数据库统统加载在内存当中进行操作,定期通过异步操作把数据库数据 flush 到硬...

35个Redis面试题

35个Redis面试题

      1.什么是redis? Redis 是一个基于内存的高性能key-value数据库。 2.Reids的特点   Redis本质上是一个Key-Value类型的内存数据库,很像memc...

【redis】高频面试题

【redis】高频面试题

1、redis和mysql怎么保证一致性 redis缓存的数据用来快速读取,但是当数据库需要更新的时候,就需要考虑两者之间的一致性。 1.1、先更新数据库,再更新缓存 或者先更新缓存,再更新数据库 这种方法在多并发的场景下都会有数据不一致的问题 1...

蚂蚁金服部门面试题解析:MySQL+Redis+MongoDB+Zookeeper+Ngnix

蚂蚁金服部门面试题解析:MySQL+Redis+MongoDB+Zookeeper+Ngnix

今天分享给大家的都是目前主流企业使用最高频的面试题库,也都是 Java 版本升级之后,重新整理归纳的最新答案,会让面试者少走很多不必要的弯路。同时每个专题都做到了详尽的面试解析文档,以确保每个阶段的读者都能看得懂,同时这部分面试文档也是可以免费的提供给有需要的同学们学习的,有需要的可以...

转:2018最全Redis面试题整理

转:2018最全Redis面试题整理

Java面试----2018最全Redis面试题整理 1、什么是Redis? 答:Redis全称为:Remote Dictionary Server(远程数据服务),是一个基于内存的高性能key-value数据库。 2、Redis的数据类型? 答:Red...

Redis面试题大全含答案

Redis面试题大全含答案 Redis面试题大全含答案 1.什么是Redis?答:Remote Dictionary Server(Redis)是一个开源的使用ANSI C语言...

三、后端开发2021面试题总结JAVA_JVM_Redis_ZooKeeper

2021年初面试总结:JAVA_JVM_Redis_ZooKeeper 以下问题是对本人在2021.01.27到2021.02.08这段时间面试过的一些互联网、传统型、初创型公司的技术问题整理。建议小伙伴们在面试前一定不要着急,先静下心来让把下面的面试题或者自...

redis面试题及答案

1、什么是Redis? Redis本质上是一个Key-Value类型的内存数据库,很像memcached,整个数据库统统加载在内存当中进行操作,定期通过异步操作把数据库数据flush到硬盘上进行保存。因为是纯内存操作,Redis的性能非常出色,每秒...

深入理解Redis,以Redis面试题来复习;Java程序员面试必备宝典

深入理解Redis,以Redis面试题来复习;Java程序员面试必备宝典

本文转载自:深入理解Redis,以Redis面试题来复习;Java程序员面试必备宝典 前言 没得前言,因为懒,都是面试题、书籍和学习资料,自己看! 一. Redis面试真题 1. 什么是 Redis?简述它的优缺点?...

Redis常见面试题

Redis常见面试题

介绍:Redis 是一个开源的使用 ANSI C 语言编写、遵守 BSD 协议、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API的非关系型数据库。 传统数据库遵循 ACID 规则。而 Nosql(Not Only SQL 的缩写,是对不...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。