01 Zookeeper 部分
CAP定理
ZAB协议
leader选举算法和流程
02 Redis 部分
Redis的应用场景
Redis支持的数据类型(必考)
zset跳表的数据结构(必考)
Redis的数据过期策略(必考)
内存淘汰策略
(1)volatile-lru:从已设置过期时间的数据集中挑选最近最少使用的数据淘汰。
(2)volatile-ttl:从已设置过期时间的数据集中挑选将要过期的数据淘汰。
(3)volatile-random:从已设置过期时间的数据集中任意选择数据淘汰。
(4)volatile-lfu:从已设置过期时间的数据集挑选使用频率最低的数据淘汰。
(5)allkeys-lru:从数据集中挑选最近最少使用的数据淘汰
(6)allkeys-lfu:从数据集中挑选使用频率最低的数据淘汰。
(7)allkeys-random:从数据集(server.db[i].dict)中任意选择数据淘汰
(8) no-enviction(驱逐):禁止驱逐数据,这也是默认策略。意思是当内存不足以容纳新入数据时,新写入操作就会报错,请求可以继续进行,线上任务也不能持续进行,采用no-enviction策略可以保证数据不被丢失。
这八种大体上可以分为4中,lru、lfu、random、ttl。
既然是淘汰,那就需要把这些数据给删除,然后保存新的。Redis 删除失效主键的方法主要有两种:
(1)消极方法(passive way),在主键被访问时如果发现它已经失效,那么就删除它。redis在实现GET、MGET、HGET、LRANGE等所有涉及到读取数据的命令时都会调用 expireIfNeeded,它存在的意义就是在读取数据之前先检查一下它有没有失效,如果失效了就删除它。
(2)积极方法(active way),周期性地探测,发现失效就删除。消极方法的缺点是,如果key 迟迟不被访问,就会占用很多内存空间,所以才有积极方式。
(3)主动删除:当内存超过maxmemory限定时,触发主动清理策略,该策略由启动参数的配置决定
Redis的LRU过期策略的具体实现
如何解决Redis缓存雪崩,缓存穿透问题
Redis的持久化机制(必考)
Redis的管道pipeline
03 Mysql 部分
事务的基本要素
事务隔离级别
如何解决事务的并发问题(脏读,幻读)?
MVCC多版本并发控制?
binlog,redolog,undolog都是什么,起什么作用?
InnoDB的行锁/表锁?
myisam和innodb的区别,什么时候选择myisam?
为什么选择B+树作为索引结构?
索引B+树的叶子节点都可以存哪些东西?
查询在什么时候不走(预期中的)索引?
sql如何优化?
explain是如何解析sql的?
order by原理
04 JVM 部分
运行时数据区域(内存模型)
垃圾回收机制
垃圾回收算法
Minor GC和Full GC触发条件
GC中Stop the world
各垃圾回收器的特点及区别
双亲委派模型
JDBC和双亲委派模型关系
05 Java 基础部分
HashMap和ConcurrentHashMap区别
ConcurrentHashMap的数据结构
高并发HashMap的环是如何产生的?
volatile作用
Atomic类如何保证原子性(CAS操作)
synchronized和Lock的区别
为什么要使用线程池?
核心线程池ThreadPoolExecutor的参数
ThreadPoolExecutor的工作流程
如何控制线程池线程的优先级
线程之间如何通信
Boolean占几个字节 1
jdk1.8/jdk1.7都分别新增了哪些特性?
Exception和Error
06 Spring 部分
Spring的IOC/AOP的实现
动态代理的实现方式
Spring如何解决循环依赖(三级缓存)
构造器注入构成的循环依赖,此种循环依赖方式是无法解决的,
只能抛出BeanCurrentlyInCreationException异常表示循环依赖。
这也是构造器注入的最大劣势(它有很多独特的优势,请小伙伴自行发掘)
根本原因:Spring解决循环依赖依靠的是Bean的“中间态”这个概念,而这个中间态指的是已经实例化,但还没初始化的状态。而构造器是完成实例化的东东,所以构造器的循环依赖无法解决~~~
不能解决的情况:
构造器注入循环依赖
prototype模式field属性注入循环依赖
能解决的情况:singleton模式field属性注入(setter方法注入)循环依赖