前言
最近一段时间发现经常看到很多人,对Spring源码比较感兴趣,日常开发中,无论你做什么什么项目,大部分都离不开Spring生态的那一套东西,所以很多人对Spring底层源码实现很感兴趣,但是有些从来没有接触过源码的开发者,在看Spring源码的过程中确实及其难受的,为什么,大部分人看源码基本都是debug一点一点去看的,最后发现,越追越离谱,越追越深,到最后都追到JDK源码了,也没有明白是什么意思!
对于学习源码,我的看法是,先去完全的熟悉它的用法,想一下如果让你来实现,你会怎么实现!有了这些想法之后,再去看源码去印证你自己的观点,远比你自己去死扣源码快的多。
而且,我问过一些读者还有同事,我发现有很多人,看源码容易陷入一个误区,就是刚开始看源码就死扣着一个细节不放,非得搞懂,我并不是说这样看源码有什么不对,但是在没有对整个框架有一个全局了解的情况下,不要这样看,你应该先把它的大体框架给搞清楚,在后再分功能一步一步的了解每一个功能项!这样做,首先你对整个框架的架构有了一个模糊的认识,再扣细节的途中有时候即使你不知道这个代码在干什么,你也隐约能猜出来,再通过debug 与自己的猜测相互印证,最终达到事半功倍的效果。当然这个建议只针对刚开始看源码的同学,如果你看的源码很多了,那么你肯定又自己的一套学习方法,可以的话,可以在评论区分享一下。
为了帮助一些萌新们或者想要了解Spring源码的小伙伴,我会把Spring的一些大体逻辑分析一下,让你了解整个Spring的骨架!
01 Redis面试问题常见划分(6个部分)
- Redis 的概念理解
- Redis 基本数据结构详解
- Redis 高并发问题策略
- Redis 集群结构以及设计理念
- Redis 持久化机制
- Redis 应用场景设计
- Redis学习路线图(xmind)
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文档,有需要的朋友可以文末领取!
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 问题?
- 如何保证缓存与数据库双写时的数据一致性?
- ... ...
我的Redis学习笔记
最后
按照上面的过程,4个月的时间刚刚好。当然Java的体系是很庞大的,还有很多更高级的技能需要掌握,但不要着急,这些完全可以放到以后工作中边用别学。
学习编程就是一个由混沌到有序的过程,所以你在学习过程中,如果一时碰到理解不了的知识点,大可不必沮丧,更不要气馁,这都是正常的不能再正常的事情了,不过是“人同此心,心同此理”的暂时而已。
“道路是曲折的,前途是光明的!”