01 Redis面试问题常见划分(6个部分)

  1. Redis 的概念理解
  2. Redis 基本数据结构详解
  3. Redis 高并发问题策略
  4. Redis 集群结构以及设计理念
  5. Redis 持久化机制
  6. Redis 应用场景设计
  7. Redis学习路线图(xmind)

java轻量级线程池框架 java线程池实战_面试

Redis学习路线图(xmind)

02 涉及到的面试题目如下

  • Redis 的特点有哪些?
  • Redis 支持的数据类型
  • 为什么 Redis 需要把所有数据放到内存中?
  • Redis 适用场景有哪些?
  • Redis常用的业务场景有哪些?
  • Mem*** 与 Redis 的区别都有哪些?
  • Redis 相比 mem***d 有哪些优势?
  • Redis常用的命令有哪些?
  • Redis 为什么设计成单线程的?
  • 一个字符串类型的值能存储最大容量是多少?
  • Redis各个数据类型最大存储量分别是多少?
  • Redis 持久化机制有哪些? 区别是什么?
  • 请介绍一下 RDB, AOF两种持久化机制的优缺点?
  • 什么是缓存穿透?怎么解决?
  • 什么是缓存雪崩? 怎么解决?
  • Redis支持的额Java客户端有哪些? 简单说明一下特点。
  • 缓存的更新策略有几种?分别有什么注意事项?
  • 什么是分布式锁?有什么作用?
  • 分布式锁可以通过什么来实现?
  • 介绍一下分布式锁实现需要注意的事项?
  • Redis怎么实现分布式锁?
  • 常见的淘汰算法有哪些?
  • Redis 淘汰策略有哪些?
  • Redis 缓存失效策略有哪些?
  • Redis 的持久化机制有几种方式?
  • 请介绍一下持久化机制 RDB, AOF的优缺点分别是什么?
  • Redis 是单线程的吗?
  • Redis 通讯协议是什么?有什么特点?
  • 请介绍一下 Redis 的数据类型 SortedSet(zset) 以及底层实现机制?
  • Redis 集群最大节点个数是多少?
  • Redis 集群的主从复制模型是怎样的?
  • Redis 如何做内存优化?
  • Redis 事务相关命令有哪些?什么是 Redis 事务?原理是什么?
  • Redis 事务的注意点有哪些?
  • Redis 为什么不支持回滚?
  • 请介绍一下 Redis 集群实现方案
  • 请介绍一下 Redis 常见的业务使用场景?
  • Redis 集群会有写操作丢失吗?为什么?
  • 请介绍一下 Redis 的 Pipeline (管道),以及使用场景
  • 请说明一下 Redis 的批量命令与 Pipeline 有什么不同?
  • Redis 慢查询是什么?通过什么配置?
  • Redis 的慢查询修复经验有哪些? 怎么修复的?
  • 请介绍一下 Redis 的发布订阅功能
  • 请介绍几个可能导致 Redis 阻塞的原因
  • 怎么去发现 Redis 阻塞异常情况?
  • Redis 的内存消耗分类有哪些?内存统计使用什么命令?
  • 简单介绍一下 Redis 的内存管理方式有哪些?
  • 如何设置 Redis 的内存上限?有什么作用?
  • 什么是 bigkey? 有什么影响?怎么发现bigkey?
  • 请简单描述一下 Jedis 的基本使用方法?
  • Jedis连接池链接方法有什么优点?
  • 冷热数据表示什么意思?
  • 缓存命中率表示什么?怎么提高缓存命中率?
  • 如何优化 Redis 服务的性能?
  • 如何实现本地缓存?请描述一下你知道的方式
  • 请介绍一下 Spring 注解缓存
  • 如果 AOF 文件的数据出现异常, Redis服务怎么处理?
  • Redis 的主从复制模式有什么优缺点?
  • Redis sentinel (哨兵) 模式优缺点有哪些?
  • Redis 集群架构模式有哪几种?
  • 如何设置 Redis 的最大连接数?查看Redis的最大连接数?查看Redis的当前连接数?
  • Redis 的链表数据结构的特征有哪些?
  • 请介绍一下 Redis 的 String 类型底层实现?
  • Redis 的 String 类型使用 SSD 方式实现的好处?
  • 设计一下在交易网站首页展示当天最热门售卖商品的前五十名商品列表?
  • … …

面试问题的答案解析太长,这边就不一一列举出来了,已经整理成如下所示的PDF文档,有需要的朋友可以文末领取!

java轻量级线程池框架 java线程池实战_java_02

Redis面试问题解析

03 最后看看我自己整理的一份Redis学习笔记

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

java轻量级线程池框架 java线程池实战_面试_03

我的Redis学习笔记

写在最后

可能有人会问我为什么愿意去花时间帮助大家实现求职梦想,因为我一直坚信时间是可以复制的。我牺牲了自己的大概十个小时写了这片文章,换来的是成千上万的求职者节约几天甚至几周时间浪费在无用的资源上。