Redis面试复习大纲在手面试不慌,内含福利

前言

这几年在Java工程师招聘时,会看到很多人的简历都写着使用了Spring Cloud做微服务实现,使用Docker做自动化部署,并且也会把这些做为自己的亮点。而比较有趣的这其中以小公司出来的人为绝大多数,大的公司出来的人简历上倒是很少提这些东西。

对于我自己来说,从15年就开始关注这一块,看过马丁.福勒最开始的关于微服务的论文、也看过不少对微服务的论证的英文文章和书,也研究过Spring Cloud、Sofa等开源实现以及Service mesh。考虑到我们公司研发团队人力不足、基础设施不完善,当初是没有推行微服务的。但随着看到上述的那种简历越来越多,有时候我也会疑问:难道真的不用微服务就落后了吗?公司的同事如果不掌握这些就真的没有竞争力了吗。而随着最近公司业务的逐步提升,研发人员越来越多,借着在梳理公司的微服务落地计划时,也梳理了一下微服务的相关知识点,也是本文的主要内容。

咱先来聊聊Redis

像Redis的基础入门,掌握下图这几个列出来的知识点足以了。

image.png

进阶的话,就得下点功夫了,事务、主从复制、哨兵、集群等等之类的搞不明白你就上不去呀。

image.png

再看美团亿级流量Redis实战,Redis分布式锁、session、缓存与数据库一致性问题、缓存雪崩等之类的都是重中之重的技术点,必须掌握,没得商量。

image.png

看了这些个技术点,那么我现在就来考考你一些Redis面试问题(准备好,接招吧):

  1. 为什么要用redis? /为什么要用缓存?
  2. 为什么要用redis而不用map/guava做缓存?
  3. 如何保证缓存与数据库双写时的数据一致性?
  4. redis 常见数据结构以及使用场景分析?(String/Hash/List/Set/Sorted Set)
  5. redis如何设置过期时间?
  6. redis内存淘汰机制(MySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据?
  7. Redis 持久化有哪几种方式,怎么选?(怎么保证redis 挂掉之后再重启数据可以进行恢复?)
  8. redis事务?
  9. Redis常见异常及解决方案?(缓存穿透/缓存雪崩/缓存预热/缓存降级)
  10. 分布式环境下常见的应用场景?(分布式锁/分布式自增ID)
  11. Redis集群模式?(主从模式/哨兵模式/Cluster集群模式)
  12. 如何解决 Redis 的并发竞争 Key 问题?

image.png

接不住的请看下方答案截图(解析不少,截取不完,可提供完整的答案解析原件):

image.png

image.png

接得住的继续,**Redis必备70题(概念+数据结构与指令+高并发处理策略+集群+缓存管理与持久化机制+应用场景设计)**答案已都整理好

  • 第一部分:Redis 的概念理解

  • 1. 什么是 Redis?

  • 2. Redis 的特点有哪些?

  • 3. Memcache 与 Redis 的区别都有哪些?

  • 4. Redis 相比 Memcached 有哪些优势?

  • 5. 如何实现本地缓存?请描述一下你知道的方式

  • 6. Redis 通讯协议是什么?有什么特点?

  • 第二部分:Redis 数据结构与指令

  • 1. Redis 支持的数据类型

  • 2. Redis 常用的命令有哪些?

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

  • 4. Redis 各个数据类型最大存储量分别是多少?

  • 5. 请介绍一下 Redis 的数据类型 SortedSet(zset)以及底层实现机制?

  • 6. Redis 事务相关命令有哪些?

  • 7. 什么是 Redis 事务?原理是什么?

  • 8. Redis 事务的注意点有哪些?

  • 9. Redis 为什么不支持回滚?

  • 10. 请介绍一下 Redis 的 Pipeline(管道),以及使用场景

  • 11. 请说明一下 Redis 的批量命令与 Pipeline 有什么不同?

  • 12. 请介绍一下 Redis 的发布订阅功能

  • 13. Redis 的链表数据结构的特征有哪些?

  • 14. 请介绍一下 Redis 的 String 类型底层实现?

  • 15. Redis 的 String 类型使用 SSD 方式实现的好处?

  • 16. 设置键的生存时间和过期时间有哪些命令?

  • 第三部分:Redis 高并发处理策略

  • 1. 为什么 Redis 需要把所有数据放到内存中?

  • 2. Redis 是单线程的吗?

  • 3. Redis 为什么设计成单线程的?

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

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

  • 6. 缓存的更新策略有几种?分别有什么注意事项?

  • 7. 请介绍几个可能导致 Redis 阻塞的原因

  • 8. 怎么去发现 Redis 阻塞异常情况?

  • 第四部分:Redis 集群结构以及设计理念

  • 1. Redis 集群架构模式有哪几种?

  • 2. Redis 集群最大节点个数是多少?

  • 3. Redis 集群的主从复制模型是怎样的?

  • 4. 请介绍一下 Redis 集群实现方案

  • 5. Redis 集群会有写操作丢失吗?为什么

  • 6. Redis 慢查询是什么?通过什么配置?

  • 7. Redis 的慢查询修复经验有哪些?怎么修复的?

  • 8. 如何优化 Redis 服务的性能?

  • 9. Redis 的主从复制模式有什么优缺点?

  • 10. Redis sentinel(哨兵)模式优缺点有哪些?

  • 11. 如何设置 Redis 的最大连接数?查看 Redis 的最大连接数?查看 Redis 的当前

  • 12. 介绍一些 Redis 常用的安全设置?

  • 第五部分:Redis 缓存管理与持久化机制

  • 1. Redis 持久化机制有哪些?

  • 2. Redis 持久化机制 AOF 和 RDB 有哪些不同之处?

  • 3. 请介绍一下 RDB 持久化机制的优缺点

  • 4. 请介绍一下 AOF 持久化机制的优缺点

  • 5. 如果 AOF 文件的数据出现异常, Redis 服务怎么处理?

  • 6. 常见的淘汰算法有哪些?

  • 7. Redis 淘汰策略有哪些?

  • 8. Redis 缓存失效策略有哪些?

  • 9. Redis 如何做内存优化?

  • 10. 什么是 bigkey? 有什么影响?

  • 11. 怎么发现 bigkey?

  • 12. Redis 的内存消耗分类有哪些?内存统计使用什么命令?

  • 13. 简单介绍一下 Redis 的内存管理方式有哪些?

  • 14. 如何设置 Redis 的内存上限?有什么作用?

  • 15. Redis 报内存不足怎么处理?

  • 第六部分:Redis 应用场景设计

  • 1. Redis 适用场景有哪些?

  • 2. Redis 常用的业务场景有哪些?

  • 3. Redis 支持的 Java 客户端有哪些? 简单说明一下特点。

  • 4. 请简单描述一下 Jedis 的基本使用方法?

  • 5. Jedis 连接池链接方法有什么优点?

  • 6. 什么是分布式锁?有什么作用?

  • 7. 分布式锁可以通过什么来实现?

  • 8. 介绍一下分布式锁实现需要注意的事项?

  • 9. Redis 怎么实现分布式锁?

  • 10. 缓存命中率表示什么?

  • 11. 怎么提高缓存命中率?

  • 12. 请介绍一下 Spring 注解缓存

聊完面试,该动手了,看看Redis实战,比如下方这本翻译过来的**《Redis In Action》**就是很不错的参考材料

image.png

全书是分三个部分:入门、核心概念、进阶内容。

  • 第一部分对Redis进行了介绍,说明了Redis的基本使用方法、它拥有的5种数据结构以及操作这5种数据结构的命令,并讲解了如何使用Redis去构建文章聚合网站、cookie、购物车、网页缓存、数据库行缓存等一系列程序。

image.png

  • 第二部分对Redis命令进行了更详细的介绍,并展示了如何使用Redis去构建更为复杂的辅助工具和应用程序,并在最后展示了如何使用Redis去构建一个简单的社交网站。

image.png

  • 第三部分对Redis用户经常会遇到的一些问题进行了介绍,讲解了降低Redis内存占用的方法、扩展Redis性能的方法以及使用Lua语言进行脚本编程的方法。

image.png

Redis就说这么多,别忘了还有MongDB

image.png

MongDB从入门到进阶再到实战,以上的技术点我都有全部列出,掌握了你就是大佬咯~

为帮助你迅速成为大牛级人物,我想这**《MongoDB用起来-快速上手》+《MongoDB用起来-集群安全》**两本笔记pdf你还是不能错过。

第一本:MongoDB快速上手

1 MongoDB相关概念

  • 1.1 业务应用场景
  • 1.2 MongoDB简介
  • 1.3 体系结构
  • 1.4 数据模型
  • 1.5 MongoDB的特点

2 单机部署

  • 2.1 Windows系统中的安装启动
  • 2.2 Shell连接(mongo命令)
  • 2.3 Compass-图形化界面客户端
  • 2.4 Linux系统中的安装启动和连接

3 基本常用命令

  • 3.1 案例需求
  • 3.2 数据库操作
  • 3.3 集合操作
  • 3.4 文档基本CRUD
  • 3.5 文档的分页查询
  • 3.6 文档的更多查询

4 索引-Index

  • 4.1 概述
  • 4.2 索引的类型
  • 4.3 索引的管理操作
  • 4.4 索引的使用

5 文章评论

  • 5.1 需求分析
  • 5.2 表结构分析
  • 5.3 技术选型
  • 5.4 文章微服务模块搭建
  • 5.5 文章评论实体类的编写
  • 5.6 文章评论的基本增删改查
  • 5.7 根据上级ID查询文章评论的分页列表
  • 5.8 MongoTemplate实现评论点赞

image.png

image.png

第二本:MongoDB集群和安全

1 副本集-Replica Sets

  • 1.1简介
  • 1.2 副本集的三个角色
  • 1.3 副本集架构目标
  • 1.4 副本集的创建
  • 1.5 副本集的数据读写操作
  • 1.6 主节点的选举原则
  • 1.7 故障测试
  • 1.8 Compass连接副本集
  • 1.9 SpringDataMongoDB连接副本集

2 分片集群-Sharded Cluster

  • 2.1 分片概念
  • 2.2 分片集群包含的组件
  • 2.3 分片集群架构目标
  • 2.4 分片(存储)节点副本集的创建
  • 2.5 配置节点副本集的创建
  • 2.6 路由节点的创建和操作
  • 2.7 Compass连接分片集群
  • 2.8 SpringDataMongDB连接分片集群
  • 2.9 清除所有的节点数据(备用)

3 安全认证

  • 3.1 MongoDB的用户和角色权限简介
  • 3.2 单实例环境
  • 3.3 副本集环境
  • 3.4 分片集群环境(扩展)
    image.png

image.png

面试准备+复习资料分享:

为了应付面试也刷了很多的面试题与资料,现在就分享给有需要的读者朋友,资料我只截取出来一部分哦,有需要的可以来找我获取哈

获取方式:点击蓝色字体即可免费获取

秋招|美团java一面二面HR面面经,分享攒攒人品

600934292)]

[外链图片转存中…(img-7ZFI0GNQ-1624600934292)]

面试准备+复习资料分享:

为了应付面试也刷了很多的面试题与资料,现在就分享给有需要的读者朋友,资料我只截取出来一部分哦,有需要的可以来找我获取哈

获取方式:点击蓝色字体即可免费获取

[外链图片转存中…(img-jJAWFzAi-1624600934293)]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/385888.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Redis面试复习大纲在手面试不慌,讲的明明白白!

前言 面试时间将近两个小时(期间等待二面面试官来面我的时候等了半个多小时)面试官问的东西很多,还挖了好几个坑,一个技术点套着一个技术点的问,一定要做好万全的准备。问了一些基本层面上的技术点都答出来了&#xf…

RocketMQ消息丢失场景及解决办法,已拿offer入职

前言 当前我们都会说SpringBoot是Spring框架对“约定优先于配置理念的最佳实践的产物,一个典型的SpringBoot应用本质上其实就是一个基于Spring框架的应用,而如果大家对Spring框架已经了如指掌,那么,在我们一步步揭开SpringBoot微…

java抓rtp包_Wireshark抓取RTP包,还原语音

最近在做基于SIP的VoIP通信研究,使用Wireshark软件可以对网络流量进行抓包。VoIP使用RTP协议对语音数据进行传输,语音载荷都封装在RTP包里面。要对传输中的语音进行截获和还原,需要通过Wireshark对RTP包进行分析和解码。该过程如下&#xff1…

RocketMQ消费者是如何获取消息的?转疯了!

前言 前两天,我收到了蚂蚁金服的offer,从朋友的内推开始面试到拿到最后offer经历了4面技术、一面交叉面和一面HR面。经过了漫长的等待和几次几乎折磨的面试之后,终于拿到了offer。 第1章:Dubbo的简史、后续的规划和整体架构大图 …

java if在内存中_java如何将对象暂存到内存中?

展开全部form表单提交文件,建议用62616964757a686964616fe59b9ee7ad9431333264623862smartupload上传,暂存在web服务器目录下,然后稍微一下下面的代码,ftp上传后,删除暂存文件,okimport java.io.File;impor…

K8S+Docker理论与实践深度集成

前言: 这篇文章主要介绍了26道Spring经典面试题总结(附带答案)的相关资料,小编在网上看到的觉得挺不错的,现在分享给大家,希望对你们有所帮助。 另外本人整理收藏了多家公司面试知识点整理 ,以及各种Java核心知识点免费分享给大…

Kafka的精髓全写这本“限量笔记”里了

前言 大厂面试真题向来是求职者的最佳练兵场,华为在Java开发工程师招聘中有哪些技术性考察和倾向?那今天咱就给大家分享一下近期的华为5面面经! 注:以下所分享的华为面试问题,相关的答案我也整理出来了,且…

MongoDB数据分布不均的解决方案

前言 算法血拼:Google百度Alibaba字节Tencent网易360拼夕夕美团 不知不觉双11就来了,轰轰烈烈的秋招也完美结束了,不知算法与数据结构成为了多少小伙伴进击大厂的绊脚石? 恰好,我这两天花了点时间,整理了些各大厂(G…

Mybatis-plus常用API全套教程

前言 前两天,我收到了蚂蚁金服的offer,从朋友的内推开始面试到拿到最后offer经历了4面技术、一面交叉面和一面HR面。经过了漫长的等待和几次几乎折磨的面试之后,终于拿到了offer。 正文 下文中截图来源于朋友一个pdf版本的面经,…

我的世界手动选择java_如何选中路径-我的世界怎么选择java路?我的世界怎么选择java路径 爱问知识人...

2014-06-03 11:26:47首先确定你安装了Java,如没有自行去官网下载最近版本 如果已安装,打开启动器,一般的启动器都有设置选项,在设置里选择正确的Java路径或者让启动器自行搜索 设置完毕后启动游戏~全部2014-06-03 11:26:472014-06…

Mycat和Mysql搭建高可用企业数据库集群

个人背景 如标题所示,我的个人背景非常简单,Java开发经验1年半,学历普通,2本本科毕业,毕业后出来就一直在Crud,在公司每天重复的工作对我的技术提升并没有什么帮助,但小镇出来的我也深知自我努…

MySQL+Tomcat+JVM,看完还怕面试官

前言 我朋友也是个写了四年Java代码的程序员,跟女友已经恋爱多年,最近突然结婚了。 他结婚以前,换了一家公司,咱俩就好久没见过面了。刚好今天出门办事碰上了,找了一家店坐一起喝酒聊天。 我聊天时打趣他&#xff1…

java因子分析_因子分析(Factor Analysis)

1 问题之前我们考虑的训练数据中样例的个数m都远远大于其特征个数n&#xff0c;这样不管是进行回归、聚类等都没有太大的问题。然而当训练样例个数m太小&#xff0c;甚至m<多元高斯分布的参数估计公式如下&#xff1a;分别是求mean和协方差的公式&#xff0c;表示样例&#…

MySQL+多线程+Redis+算法+网络

开头 我们面试的时候 &#xff0c;经常会被问这种到问题:Spring中bean的循环依赖怎么解决&#xff1f; Spring中bean的加载过程&#xff1f; spring相关的问题一直是大厂面试常问到的一个问题,也是一直困扰这我们&#xff0c;不知道从哪里下手&#xff0c;今天举例分析大厂的一…

python 函数进度条怎么_python输出结果刷新及进度条的实现操作

print函数python输出主要使用print函数&#xff0c;print函数介绍&#xff1a;print(*objects, sep" ", end"", filesys.stdout, flushFalse)*objects表示要打印的值&#xff0c;表示多个无名参数或需要打印的值&#xff1b;sep" "&#xff0c;对…

MySQL优化原理分析及优化方案总结

前言 今天中午收到我司安全部发了一封邮件&#xff1a;Jackson存在安全漏洞。查了一下&#xff0c;这件事并不算很新鲜了&#xff08;已经过了5天的样子&#xff09;&#xff0c;本文来聊聊吧。 说起来还蛮戏剧化&#xff1a;阿里云向Jackson官方提交了一个Jackson序列化安全…

MySQL千万数据量深分页优化

前言 提到MySQL的事务&#xff0c;我相信对MySQL有了解的同学都能聊上几句&#xff0c;无论是面试求职&#xff0c;还是日常开发&#xff0c;MySQL的事务都跟我们息息相关。 而事务的ACID&#xff08;即原子性Atomicity、一致性Consistency、隔离性Isolation、持久性Durabili…

Mysql和Redis数据同步该怎么做

前言 算法血拼&#xff1a;Google百度Alibaba字节Tencent网易360拼夕夕美团 不知不觉双11就来了,轰轰烈烈的秋招也完美结束了,不知算法与数据结构成为了多少小伙伴进击大厂的绊脚石&#xff1f; 恰好&#xff0c;我这两天花了点时间&#xff0c;整理了些各大厂&#xff08;G…

java源代码保存在扩展名为,看完跪了

正文 在实际的工作项目中&#xff0c; 缓存成为高并发、高性能架构的关键组件 &#xff0c;那么Redis为什么可以作为缓存使用呢&#xff1f;首先可以作为缓存的两个主要特征&#xff1a; 在分层系统中处于内存/CPU具有访问性能良好&#xff0c;缓存数据饱和&#xff0c;有良好…

java源码文件丢恢复需要多少钱,上岸蚂蚁金服!

京东Java研发岗一面&#xff08;基础面&#xff0c;约1小时&#xff09; 自我介绍&#xff0c;主要讲讲做了什么和擅长什么 springmvc和spring-boot区别 Autowired的实现原理 Bean的默认作用范围是什么&#xff1f;其他的作用范围&#xff1f; 索引是什么概念有什么作用&am…