Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >2022年Java秋招面试,程序员求职必看的Redis面试题

2022年Java秋招面试,程序员求职必看的Redis面试题

原创
作者头像
Java程序猿
修改于 2022-07-13 13:51:25
修改于 2022-07-13 13:51:25
7260
举报
文章被收录于专栏:Java核心技术Java核心技术

前言

作为一个后端开发人员,不只是要求开发人员需要掌握 Redis,也要求运维人员也要懂 Redis。由于 Redis 的运用广泛,我们也知道它的重要性,至此面试中经常被问到。如果你最近在准备面试或者在学习 Redis,我相信本篇可以满足你的面试需要。也希望我花了半个月整理的这些题目,解答对你有所帮助。

小编分享的这份2022年Java秋招备战面试题总计有1000多道面试题,包含了MyBatis、ZooKeeper、Dubbo、Elasticsearch、Memcached、Redis、MySQLJava 并发编程、Java基础、Spring、微服务、LinuxSpring Boot 、Spring Cloud、RabbitMQ、kafka等16个专题技术点,都是小编在今年金三银四总结出来的面试真题,已经有很多粉丝靠这份PDF拿下众多大厂的offer,今天在这里总结分享给到大家!【已完结】

1、什么是Redis?

Redis 是完全开源免费的,遵守 BSD 协议,是一个高性能的 key-value 数据库

Redis 与其他 key - value 缓存产品有以下三个特点:

  • Redis 支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
  • Redis 不仅仅支持简单的 key-value 类型的数据,同时还提供 list,set,zset,hash 等数据结构的存储。
  • Redis 支持数据的备份,即 master-slave 模式的数据备份

Redis 优势

  • 性能极高 – Redis 能读的速度是 110000 次/s,写的速度是 81000 次/s 。
  • 丰富的数据类型 – Redis 支持二进制案例的 Strings, Lists, Hashes, Sets 及Ordered Sets 数据类型操作。
  • 原子 – Redis 的所有操作都是原子性的,意思就是要么成功执行要么失败完全不执行。单个操作是原子性的。多个操作也支持事务,即原子性,通过 MULTI 和 EXEC指令包起来。
  • 丰富的特性 – Redis 还支持 publish/subscribe, 通知, key 过期等等特性。

Redis 与其他 key-value 存储有什么不同?

Redis 有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis 的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象。

Redis 运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上相同的复杂的数据结构,在内存中操作起来非常简单,这样 Redis可以做很多内部复杂性很强的事情。同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。

2、Redis的数据类型?

3、使用Redis有哪些好处?

1、速度快,因为数据存在内存中,类似于 HashMap,HashMap 的优势就是查找和操作的时间复杂度都是 O1)

2、支持丰富数据类型,支持 string,list,set,Zset,hash 等

3、支持事务,操作都是原子性,所谓的原子性就是对数据的更改要么全部执行,要么全部不执行

4、丰富的特性:可用于缓存,消息,按 key 设置过期时间,过期后将会自动删除

4、Redis相比Memcached有哪些优势?

1、Memcached 所有的值均是简单的字符串,redis 作为其替代者,支持更为丰富的数据类

2、Redis 的速度比 Memcached 快很

3、Redis 可以持久化其数据

5、Memcache与Redis的区别都有哪些?

1、存储方式 Memecache 把数据全部存在内存之中,断电后会挂掉,数据不能超过内存大小。 Redis 有部份存在硬盘上,这样能保证数据的持久性。

2、数据支持类型 Memcache 对数据类型支持相对简单。 Redis 有复杂的数据类型。

3、使用底层模型不同 它们之间底层实现方式 以及与客户端之间通信的应用协议不一样。 Redis 直接自己构建了 VM 机制 ,因为一般的系统调用系统函数的话,会浪费一定的时间去移动和请求。

6、Redis是单进程单线程的?

答:Redis 是单进程单线程的,redis 利用队列技术将并发访问变为串行访问,消除了传统数据库串行控制的开销。

7、一个字符串类型的值能存储最大容量是多少?

答:512M

8、Redis的持久化机制是什么?各自的优缺点?

Redis 提供两种持久化机制 RDB 和 AOF 机制:

1、RDBRedis DataBase)持久化方式: 是指用数据集快照的方式半持久化模式)记录 redis 数据库的所有键值对,在某个时间点将数据写入一个临时文件,持久化结束后,用这个临时文件替换上次持久化的文件,达到数据恢复

优点:

1、只有一个文件 dump.rdb,方便持久化。

2、容灾性好,一个文件可以保存到安全的磁盘。

3、性能最大化,fork 子进程来完成写操作,让主进程继续处理命令,所以是 IO最大化。使用单独子进程来进行持久化,主进程不会进行任何 IO 操作,保证了 redis的高性能) 4.相对于数据集大时,比 AOF 的启动效率更高。

缺点:

1、数据安全性低。RDB 是间隔一段时间进行持久化,如果持久化之间 redis 发生故障,会发生数据丢失。所以这种方式更适合数据要求不严谨的时候)

2、AOFAppend-only file)持久化方式: 是指所有的命令行记录以 redis 命令请求协议的格式完全持久化存储)保存为 aof 文件。

9、Redis常见性能问题和解决方案:

10、redis过期键的删除策略?

11、Redis的回收策略(淘汰策略)?

使用策略规则:

1、如果数据呈现幂律分布,也就是一部分数据访问频率高,一部分数据访问频率低,则使用 allkeys-lru

2、如果数据呈现平等分布,也就是所有的数据访问频率都相同,则使用allkeys-random

12、为什么edis需要把所有数据放到内存中?

13、Redis的同步机制了解么?

14、Pipeline有什么好处,为什么要用pipeline?

15、是否使用过Redis集群,集群的原理是什么?

16、Redis集群方案什么情况下会导致整个集群不可用?

答:有 A,B,C 三个节点的集群,在没有复制模型的情况下,如果节点 B 失败了,那么整个集群就会以为缺少 5501-11000 这个范围的槽而不可用。

17、Redis支持的Java客户端都有哪些?官方推荐用哪个?

答:Redisson、Jedis、lettuce 等等,官方推荐使用 Redisson。

18、Jedis与Redisson对比有什么优缺点?

19、Redis如何设置密码及验证密码?

设置密码:config set requirepass 123456

授权密码:auth 123456

20、说说Redis哈希槽的概念?

21、Redis集群的主从复制模型是怎样的?

答:为了使在部分节点失败或者大部分节点无法通信的情况下集群仍然可用,所以集群使用了主从复制模型,每个节点都会有 N-1 个复制品.

22、Redis集群会有写操作丢失吗?为什么?

答:Redis 并不能保证数据的强一致性,这意味这在实际中集群在特定的条件下可能会丢失写操作。

23、Redis集群之间是如何复制的?

答:异步复制

24、Redis集群最大节点个数是多少?

25、Redis集群如何选择数据库?

答:16384 个。

26、怎么测试Redis的连通性?

答:Redis 集群目前无法做数据库选择,默认在 0 数据库。

27、怎么理解Redis事务?

28、Redis事务相关的命令有哪几个?

答:MULTI、EXEC、DISCARD、WATCH

29、Redis key的过期时间和永久有效分别怎么设置?

答:EXPIRE 和 PERSIST 命令。

30、Redis如何做内存优化?

31、Redis回收进程如何工作的?

32、都有哪些办法可以降低Redis的内存使用情况呢?

33、Redis的内存用完了会发生什么?

34、一个Redis实例最多能存放多少的keys?List、Set、Sorted Set他们最多能存

35、MySQL里有2000w数据,redis中只存20w的数据,如何保证redis中的数据都是热点

36、Redis最适合的场景?

Reids 在内存存储引擎领域的一大优点是提供 list 和 set 操作,这使得 Redis能作为一个很好的消息队列平台来使用。Redis 作为队列使用的操作,就类似于本地程序语言(如 Python)对 list 的 push/pop 操作。 如果你快速的在 Google中搜索“Redis queues”,你马上就能找到大量的开源项目,这些项目的目的就是利用 Redis 创建非常好的后端工具,以满足各种队列需求。例如,Celery 有一个后台就是使用 Redis 作为 broker,你可以从这里去查看。

37、假如Redis里面有1亿个key,其中有10w个key是以某个固定的已知的前缀开头的,如果将它

答:使用 keys 指令可以扫出指定模式的 key 列表。

38、如果有大量的key需要设置同一时间过期,一般需要注意什么?

答:如果大量的 key 过期时间设置的过于集中,到过期的那个时间点,redis 可能会出现短暂的卡顿现象。一般需要在时间上加一个随机值,使得过期时间分散一些。

39、使用过Redis做异步队列么,你是怎么用的?

答:一般使用 list 结构作为队列,rpush 生产消息,lpop 消费消息。当 lpop 没有消息的时候,要适当 sleep 一会再重试。

如果对方追问可不可以不用 sleep 呢?

list 还有个指令叫 blpop,在没有消息的时候,它会阻塞住直到消息到来。如果对方追问能不能生产一次消费多次呢?使用 pub/sub 主题订阅者模式,可以实现1:N 的消息队列。

如果对方追问 pub/sub 有什么缺点?

在消费者下线的情况下,生产的消息会丢失,得使用专业的消息队列如 RabbitMQ等。

如果对方追问 redis 如何实现延时队列?

我估计现在你很想把面试官一棒打死如果你手上有一根棒球棍的话,怎么问的这么详细。但是你很克制,然后神态自若的回答道:使用 sortedset,拿时间戳作为score,消息内容作为 key 调用 zadd 来生产消息,消费者用 zrangebyscore 指令获取 N 秒之前的数据轮询进行处理。到这里,面试官暗地里已经对你竖起了大拇指。但是他不知道的是此刻你却竖起了中指,在椅子背后。

40、使用过Redis分布式锁么,它是什么回事?

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
一篇m6A综述的阅读笔记
Hailing Shi, Jiangbo Wei, Chuan He,Where, When, and How: Context-Dependent Functions of RNA Methylation Writers, Readers, and Erasers,Molecular Cell,Volume 74, Issue 4,2019,Pages 640-650, ISSN 1097-2765,https://doi.org/10.1016/j.molcel.2019.04.025.
Chris生命科学小站
2023/02/28
5930
一篇m6A综述的阅读笔记
热点综述 | m6A × 肿瘤相关lncRNA研究思路
搞科研,关注热点很重要,比如最近小编疯狂更新的单细胞和空间组学;今天咱们换个方向,插播一条国自然热点:m6A修饰。
尐尐呅
2022/04/01
5710
热点综述 | m6A × 肿瘤相关lncRNA研究思路
NAR | 上交医学院余健秀课题组发表m6A最新研究成果
日前,上海交通大学医学院余健秀研究组在Nucleic Acids Research杂志上在线发表“SUMOylation of YTHDF2 promotes mRNA degradation and cancer progression by increasing its binding affinity with m6A-modified mRNAs”论文。该研究揭示SUMO化修饰是m6A修饰阅读蛋白YTHDF2功能调控的一个新分子机制,并阐明了其在肿瘤发生中的重要作用。
生信交流平台
2022/09/21
3530
NAR | 上交医学院余健秀课题组发表m6A最新研究成果
m6A调节因子在肾透明细胞中的基因特征和预后价值:一项使用TCGA数据库的回顾性研究
真核生物RNA可以携带100多种化学修饰,其中RNA甲基化修饰约占60%,而N6-甲基腺嘌呤(m6A)在甲基化修饰中最为普遍,占有率高达80%。从2017年至今,RNA m6A研究热度不减,已有7篇在《Nature》、2篇在《Cell》、2篇在《Cancer cell》上发表。
用户1359560
2019/04/17
2K0
m6A调节因子在肾透明细胞中的基因特征和预后价值:一项使用TCGA数据库的回顾性研究
常见肿瘤RNA m6A修饰研究的最新发文套路解析
小编这次要分享的两篇高分文献,是今年5月发表在Gut和Mol Cancer杂志的两篇文章,一个研究胃癌一个研究胰腺癌,都是很经典的研究套路。今天小编就为大家深度剖析文章思路,特别是就如何找到关键问题:怎么找到受甲基化酶调控的靶基因?做了具体的展示。
生信交流平台
2020/08/05
1.5K0
常见肿瘤RNA m6A修饰研究的最新发文套路解析
王秀杰研究组合作发现m6A修饰在小脑发育中的新功能 (附2018上半年m6A研究文章和点评)
N6-甲基腺嘌呤(m6A)修饰是RNA上分布最广泛的一种化学修饰,参与调控RNA的翻译、降解以及可变剪接等多个过程,在胚胎干细胞干性维持、胚胎发育、配子发生等生命活动中均发挥重要作用。m6A修饰是由METTL3、METTL14以及WTAP等构成的m6A甲基转移酶复合物催化形成的,其中METTL3是m6A甲基转移复合物的核心组分。在小鼠中,敲除Mettl3基因可导致早期胚胎发育终止,表明m6A甲基化修饰在哺乳动物胚胎发育中扮演重要角色。   中国科学院遗传与发育生物学研究所王秀杰研究组与动物所周琪研究组、基因
生信宝典
2018/06/22
1K0
肿瘤研究中加入m6A热点发表15分文章是什么水平?
胃癌(GC)虽然根治性切除和全身化疗已经有了很大的改善,但由于恶性增殖和转移,其预后仍然很差。因此,迫切需要阐明胃癌进展的潜在分子机制,这将有助于靶向治疗的发展。M6A甲基化是真核mRNAs中最普遍的修饰之一。之前的研究报道,m6A修饰的作用包括调节mRNA的稳定性、剪接和翻译。甲基转移酶3(METTL3)是一种催化酶,能促进mRNAs的m6A修饰。今天笔者带来一篇文章详细研究了METTL3介导BATF2的m6A修饰影响胃癌进展。这篇文章发表于2020年7月发表在Molecular Cancer(IF=15.3)上,文章研究思路清晰,实验结果交叉验证,细致又严谨,对于梳理肿瘤和m6A思路是一篇非常好的研究。
生信交流平台
2020/09/22
9230
肿瘤研究中加入m6A热点发表15分文章是什么水平?
8分+的m6A甲基化分析思路
m6A甲基化修饰是哺乳动物蛋白质编码mRNA中最普遍的RNA修饰,是一种具有多种重要生物功能的可逆修饰。m6A的形成和功能由甲基转移酶(writers)、去甲基化酶(erasers)和结合蛋白(readers)作为关键因素来调节。
作图丫
2022/03/28
6060
8分+的m6A甲基化分析思路
RNA甲基化
DNA甲基化大家肯定都不陌生,而这几年却发现了RNA甲基化的呼声甚至比DNA甲基化更高。那RNA甲基化到底是什么呢?
生信交流平台
2020/08/06
2.1K0
RNA甲基化
表观转录组学-m6A简介
DNA甲基化作为重要的表观遗传学标记,研究的非常广泛。与DNA相对应,在RNA水平也存在着多种化学修饰,已经发现的就有100种以上,在编码和非编码RNA上都存在。常见的几种mRNA上的化学修饰如下图所示
生信修炼手册
2020/05/07
1.7K0
m6A甲基化数据分析流程
前面我们简单介绍过m6A RNA甲基化修饰特征,以及RNA m6A修饰发文套路大揭秘。那么今天小天就和大家一起探讨一下,m6A甲基化数据分析的基本流程。
生信交流平台
2022/09/21
1.4K0
m6A甲基化数据分析流程
转录组讲师带你读文献-m6A和RNA测序结合
我在我在04-转录组笔记推文任务列表(半年期)里面安排了6个经典综述和10篇转录组应用文献给大家,可惜愿意沉下心了认真苦学的并不多。(https://share.mubu.com/doc/14uneHKvPg)
生信技能树
2021/05/27
2.2K0
转录组讲师带你读文献-m6A和RNA测序结合
纯生信m6A篇:内部套路大曝光
无论医疗工作者还是研究生等等,如何在繁忙的工作生活中运用最短的时间,无需做实验发一篇SCI,一直是我们最头疼的问题!而纯生信文章就是作为SCI入门级别的不二选择。小编今天为大家介绍一篇近期发表的热点m6A的纯生信文章。
百味科研芝士
2020/07/29
1.4K0
纯生信m6A篇:内部套路大曝光
癌症中的长非编码RNA与RNA结合蛋白的相互作用
今天为大家介绍的是来自Nehad M. Alajez团队的一篇综述。了解非编码RNA(ncRNA)在我们的DNA中扮演的重要角色对于理解癌症的许多方面至关重要。这些ncRNA是一大类分子,它们不参与制造蛋白质,但在控制我们细胞的各种过程中有着重要的作用。这些过程就像规定我们细胞如何运作的规则。这些ncRNA的工作方式之一是与另一种分子,称为RNA结合蛋白(RBP),进行互动,这种互动在不同类型的癌症中都有详细的了解。它们一起可以影响ncRNA和RBP的稳定性,RNA分子的修改方式,它们在细胞中的位置,以及在癌症中发挥作用的许多其他机制。
DrugAI
2023/12/04
4830
癌症中的长非编码RNA与RNA结合蛋白的相互作用
Cell 关于 小和长非编码RNA 的最新综述,万字精读
生信菜鸟团
2024/11/28
5500
Cell 关于 小和长非编码RNA 的最新综述,万字精读
25个表观遗传学数据库,你需要的全都有!
表观遗传学是与遗传学(genetic)相对应的概念。遗传学是指基于基因序列改变所 致基因表达水平变化,如基因突变、基因杂合丢失和微卫星不稳定等;而表观遗传学则是指基于非基因序列改变所致基因表达水平变化,如DNA甲基化和染色质构象变 化等;表观基因组学(epigenomics) 则是在基因组水平上对表观遗传学改变的研究。
作图丫
2022/03/29
2.5K0
25个表观遗传学数据库,你需要的全都有!
MCE| 组蛋白甲基转移酶 SETD2 抑制前列腺癌转移的机制
近日,中国科学院上海营养与健康研究所秦骏课题组与陆军军医大学大坪医院江军主任、南京医科大学王晓明教授的合作在 Cancer Cell 在线发表了题为 “SETD2 Restricts Prostate Cancer Metastasis by Integrating EZH2 and AMPK Signaling Pathways” 的研究,揭示了 H3K36 甲基转移酶 SETD2 通过底物 EZH 限制前列腺癌的转移的分子机制。
MedChemExpress
2023/03/15
4280
MCE| 组蛋白甲基转移酶 SETD2 抑制前列腺癌转移的机制
miRNA -- 触发 RNA 干扰,让基因 “沉默”| MedChemExpress
1993 年,科学家 Victor Ambros 等人在研究线虫时发现了一种名为 LIN-4 的基因,该基因表达一种小 RNA,可以抑制一种核蛋白 LIN-14 基因的表达[1]。这一小 RNA 就是第一个被报道的 miRNA (见往期推文:小分子和小 RNA 的大大 “梦想”)。此后,成千上万的 miRNA 在包括人类、小鼠、大鼠、斑马鱼、果蝇、水稻、拟南芥等几乎所有类群中陆续 “浮出水面”……
MedChemExpress
2023/03/24
9820
miRNA -- 触发 RNA 干扰,让基因 “沉默”| MedChemExpress
RNA剪接增强免疫检查点抑制疗效 | MedChemExpress
真核生物基因包含一系列外显子和内含子,内含子必须在转录过程中被移除以便成熟的 mRNA 被翻译成蛋白质,RNA 剪接则是这一过程中至关重要的一步。RNA 剪接包含两类剪接事件。
MedChemExpress
2023/02/28
2750
RNA剪接增强免疫检查点抑制疗效 | MedChemExpress
全长转录组 | ONT Direct RNA测序 (DRS) 技术原理、数据分析和应用
"牛津纳米孔技术公司(Oxford Nanopore Technologies,ONT)开发的第三代测序平台是 目前唯一能够直接对天然RNA链进行测序的技术平台。ONT - Direct RNA Sequecing (DRS,直接RNA测序)技术能够对天然全长RNA链进行测序,同时能够保留并检测RNA碱基的修饰信息,并能够相对准确地估算 poly(A) 尾的长度,从而还原RNA的真实特征。"
三代测序说
2024/08/08
2.1K0
全长转录组 | ONT Direct RNA测序 (DRS) 技术原理、数据分析和应用
推荐阅读
相关推荐
一篇m6A综述的阅读笔记
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档