前言

进大厂是大部分程序员的梦想,而进大厂的门槛也是比较高的,让我们来看看阿里的招聘信息。

【51CTO博客最全】2021阿里Java后端面试真题汇总【年后逆袭上位P8】

再来看看美团的架构师需要的要求以及经验!

【51CTO博客最全】2021阿里Java后端面试真题汇总【年后逆袭上位P8】

​所以小编这里整理了一份阿里、美团、滴滴、头条等大厂面试大全其中概括的知识点有:Java基础、spring、springmvc、springboot、springcloud、JVM、Tomcat、dubbo、netty、zookeeper等29个Java核心技术栈,由于文章篇幅有限,对应的面试题会部分列举出来,JAVA核心知识点整理总结【附答案解析】,编程的世界永远向所有热爱编程的人开放,这是一个自由,平等,共享的世界,我始终是这样坚信的。

点开观看的小伙伴可以先了解一下目录

  1. JVM
  2. JAVA 集合
  3. JAVA多线程并发
  4. JAVA基础
  5. Spring原理
  6. 微服务
  7. Netty与RPC
  8. 网络
  9. 日志
  10. Zookeeper
  11. Kafka
  12. RabbitMQ
  13. Hbase
  14. MongoDB
  15. Cassandra
  16. 设计模式
  17. 负载均衡
  18. 数据库
  19. 一致性算法
  20. JAVA算法
  21. 数据结构
  22. 加密算法
  23. 分布式缓存
  24. Hadoop
  25. Spark
  26. Storm
  27. YARN
  28. 机器学习
  29. 云计算

Java基础

  1. Java概述
  2. 何为编程
  3. 什么是Java
  4. jdk1.5之后的三大版本
  5. JVM、JRE和JDK的关系
  6. 什么是跨平台性?原理是什么
  7. Java语言有哪些特点
  8. 什么是字节码?采用字节码的最大好处是什么
  9. 什么是Java程序的主类?应用程序和小程序的主类有何不同?
  10. Java应用程序与小程序之间有那些差别?
  11. Java和C++的区别
  12. Oracle JDK 和 OpenJDK 的对比
  13. 基础语法
  14. 数据类型
  15. Java有哪些数据类型
  16. switch 是否能作用在 byte 上,是否能作用在 long 上,是否能作用在 String 上
  17. 用最有效率的方法计算 2 乘以 8
  18. Math.round(11.5) 等于多少?Math.round(-11.5)等于多少
  19. float f=3.4;是否正确
  20. short s1 = 1; s1 = s1 + 1;有错吗?short s1 = 1; s1 += 1;有错吗
  21. 编码
  22. Java语言采用何种编码方案?有何特点?
  23. 注释
  24. 什么Java注释
  25. 访问修饰符
  26. 访问修饰符 public,private,protected,以及不写(默认)时的区别
  27. 运算符
  28. &和&&的区别
  29. 关键字
  30. Java 有没有 goto
  31. final 有什么用?
  32. final finally finalize区别
  33. this关键字的用法
  34. super关键字的用法
  35. this与super的区别
  36. static存在的主要意义
  37. static的独特之处
  38. static应用场景
  39. static注意事项
  40. 流程控制语句
  41. break ,continue ,return 的区别及作用
  42. 在 Java 中,如何跳出当前的多重嵌套循环
  43. 面向对象
  44. 面向对象概述
  45. 面向对象和面向过程的区别
  46. 面向对象三大特性
  47. 面向对象的特征有哪些方面
  48. 什么是多态机制?Java语言是如何实现多态的?
  49. 面向对象五大基本原则是什么(可选)
  50. 类与接口
  51. 抽象类和接口的对比
  52. 普通类和抽象类有哪些区别?
  53. 抽象类能使用 final 修饰吗?
  54. 创建一个对象用什么关键字?对象实例与对象引用有何不同?
  55. 变量与方法
  56. 成员变量与局部变量的区别有哪些
  57. 在Java中定义一个不做事且没有参数的构造方法的作用
  58. 在调用子类构造方法之前会先调用父类没有参数的构造方法,其目的是?
  59. 一个类的构造方法的作用是什么?若一个类没有声明构造方法,该程序能正确执行吗?为什么?
  60. 构造方法有哪些特性?
  61. 静态变量和实例变量区别
  62. 静态变量与普通变量区别
  63. 静态方法和实例方法有何不同?
  64. 在一个静态方法内调用一个非静态成员为什么是非法的?
  65. 什么是方法的返回值?返回值的作用是什么?
  66. 内部类
  67. 什么是内部类?
  68. 内部类的分类有哪些
  69. 静态内部类
  70. 成员内部类
  71. 局部内部类
  72. 匿名内部类
  73. 内部类的优点
  74. 内部类有哪些应用场景
  75. 局部内部类和匿名内部类访问局部变量的时候,为什么变量必须要加上final?
  76. 内部类相关,看程序说出运行结果
  77. 重写与重载
  78. 构造器(constructor)是否可被重写(override)
  79. 重载(Overload)和重写(Override)的区别。重载的方法能否根据返回类型进行区分?
  80. 对象相等判断
  81. == 和 equals 的区别是什么
  82. hashCode 与 equals (重要)
  83. 对象的相等与指向他们的引用相等,两者有什么不同?
  84. 值传递
  85. 当一个对象被当作参数传递到一个方法后,此方法可改变这个对象的属性,并可返回变化后的结果,那么这里到底是值传递还是引用传递
  86. 为什么 Java 中只有值传递
  87. 值传递和引用传递有什么区别
  88. Java包
  89. JDK 中常用的包有哪些
  90. import java和javax有什么区别
  91. IO流
  92. java 中 IO 流分为几种?
  93. BIO,NIO,AIO 有什么区别?
  94. Files的常用方法都有哪些?
  95. 反射
  96. 什么是反射机制?
  97. 反射机制优缺点
  98. 反射机制的应用场景有哪些?
  99. Java获取反射的三种方法
  100. 网络编程
  101. 常用API
  102. String相关
  103. 字符型常量和字符串常量的区别
  104. 什么是字符串常量池?
  105. String 是最基本的数据类型吗
  106. String有哪些特性
  107. String为什么是不可变的吗?
  108. String真的是不可变的吗?
  109. 是否可以继承 String 类
  110. String str="i"与 String str=new String("i")一样吗?
  111. String s = new String("xyz");创建了几个字符串对象
  112. 如何将字符串反转?
  113. 数组有没有 length()方法?String 有没有 length()方法
  114. String 类的常用方法都有那些?
  115. 在使用 HashMap 的时候,用 String 做 key 有什么好处?
  116. String和StringBuffer、StringBuilder的区别是什么?String为什么是不可变的
  117. Date相关
  118. 包装类相关
  119. 自动装箱与拆箱
  120. int 和 Integer 有什么区别
  121. Integer a= 127 与 Integer b = 127相等吗
  122. 常用工具类库
  123. 单元测试
  124. 日志

附答案解析

JVM

  1. 说一下 JVM 的主要组成部分及其作用?
  2. 说一下 JVM 运行时数据区
  3. 说一下堆栈的区别?
  4. 队列和栈是什么?有什么区别?
  5. 对象的创建
  6. 为对象分配内存
  7. 处理并发安全问题
  8. 对象的访问定位
  9. 句柄访问
  10. 直接指针
  11. 内存溢出异常
  12. Java会存在内存泄漏吗?请简单描述垃圾收集器
  13. 简述Java垃圾回收机制
  14. GC是什么?为什么要GC
  15. 垃圾回收的优点和原理。并考虑2种回收机制
  16. 垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法主动通知虚拟机进行垃圾回收?
  17. Java 中都有哪些引用类型?
  18. 怎么判断对象是否可以被回收?
  19. 在Java中,对象什么时候可以被垃圾回收
  20. JVM中的永久代中会发生垃圾回收吗
  21. 说一下 JVM 有哪些垃圾回收算法?
  22. 标记-清除算法
  23. 复制算法
  24. 标记-整理算法
  25. 分代收集算法
  26. 说一下 JVM 有哪些垃圾回收器?
  27. 详细介绍一下 CMS 垃圾回收器?
  28. 新生代垃圾回收器和老年代垃圾回收器都有哪些?有什么区别?
  29. 简述分代垃圾回收器是怎么工作的?
  30. 简述java内存分配与回收策率以及Minor GC和Major GC
  31. 对象优先在 Eden 区分配
  32. 大对象直接进入老年代
  33. 长期存活对象将进入老年代
  34. 简述java类加载机制?
  35. 描述一下JVM加载Class文件的原理机制
  36. 什么是类加载器,类加载器有哪些?
  37. 说一下类装载的执行过程?
  38. 什么是双亲委派模型?
  39. 说一下 JVM 调优的工具?
  40. 常用的 JVM 调优的参数都有哪些?

Spring

  1. Spring概述(10)
  2. 什么是spring?
  3. Spring框架的设计目标,设计理念,和核心是什么
  4. Spring的优缺点是什么?
  5. Spring有哪些应用场景
  6. Spring由哪些模块组成?
  7. Spring 框架中都用到了哪些设计模式?
  8. 详细讲解一下核心容器(spring context应用上下文) 模块
  9. Spring框架中有哪些不同类型的事件
  10. Spring 应用程序有哪些不同组件?
  11. 使用 Spring 有哪些方式?
  12. Spring控制反转(IOC)(13)
  13. 什么是Spring IOC 容器?
  14. 控制反转(IoC)有什么作用
  15. IOC的优点是什么?
  16. Spring IoC 的实现机制
  17. Spring 的 IoC支持哪些功能
  18. BeanFactory 和 ApplicationContext有什么区别?
  19. Spring 如何设计容器的,BeanFactory和ApplicationContext的关系详解
  20. ApplicationContext通常的实现是什么?
  21. 什么是Spring的依赖注入?
  22. 依赖注入的基本原则
  23. 依赖注入有什么优势
  24. 有哪些不同类型的依赖注入实现方式?
  25. 构造器依赖注入和 Setter方法注入的区别
  26. Spring Beans(19)
  27. 什么是Spring beans?
  28. 一个 Spring Bean 定义 包含什么?
  29. 如何给Spring 容器提供配置元数据?Spring有几种配置方式
  30. Spring配置文件包含了哪些信息
  31. Spring基于xml注入bean的几种方式
  32. 你怎样定义类的作用域?
  33. 解释Spring支持的几种bean的作用域
  34. Spring框架中的单例bean是线程安全的吗?
  35. Spring如何处理线程并发问题?
  36. 解释Spring框架中bean的生命周期
  37. 哪些是重要的bean生命周期方法? 你能重载它们吗?
  38. 什么是Spring的内部bean?什么是Spring inner beans?
  39. 在 Spring中如何注入一个java集合?
  40. 什么是bean装配?
  41. 什么是bean的自动装配?
  42. 解释不同方式的自动装配,spring 自动装配 bean 有哪些方式?
  43. 使用@Autowired注解自动装配的过程是怎样的?
  44. 自动装配有哪些局限性?
  45. 你可以在Spring中注入一个null 和一个空字符串吗?
  46. Spring注解(8)
  47. 什么是基于Java的Spring注解配置? 给一些注解的例子
  48. 怎样开启注解装配?
  49. @Component, @Controller, @Repository, @Service 有何区别?
  50. @Required 注解有什么作用
  51. @Autowired 注解有什么作用
  52. @Autowired和@Resource之间的区别
  53. @Qualifier 注解有什么作用
  54. @RequestMapping 注解有什么用?
  55. Spring数据访问(14)
  56. 解释对象/关系映射集成模块
  57. 在Spring框架中如何更有效地使用JDBC?
  58. 解释JDBC抽象和DAO模块
  59. spring DAO 有什么用?
  60. spring JDBC API 中存在哪些类?
  61. JdbcTemplate是什么
  62. 使用Spring通过什么方式访问Hibernate?使用 Spring 访问 Hibernate 的方法有哪些?
  63. 如何通过HibernateDaoSupport将Spring和Hibernate结合起来?
  64. Spring支持的事务管理类型, spring 事务实现方式有哪些?
  65. Spring事务的实现方式和实现原理
  66. 说一下Spring的事务传播行为
  67. 说一下 spring 的事务隔离?
  68. Spring框架的事务管理有哪些优点?
  69. 你更倾向用那种事务管理类型?
  70. Spring面向切面编程(AOP)(13)
  71. 什么是AOP
  72. Spring AOP and AspectJ AOP 有什么区别?AOP 有哪些实现方式?
  73. JDK动态代理和CGLIB动态代理的区别
  74. 如何理解 Spring 中的代理?
  75. 解释一下Spring AOP里面的几个名词
  76. Spring在运行时通知对象
  77. Spring只支持方法级别的连接点
  78. 在Spring AOP 中,关注点和横切关注的区别是什么?在 spring aop 中 concern 和 cross-cutting concern 的不同之处
  79. Spring通知有哪些类型?
  80. 什么是切面 Aspect?
  81. 解释基于XML Schema方式的切面实现
  82. 解释基于注解的切面实现
  83. 有几种不同类型的自动代理?

SpringMVC

  1. 什么是Spring MVC?简单介绍下你对Spring MVC的理解?
  2. Spring MVC的优点
  3. Spring MVC的主要组件?
  4. 什么是DispatcherServlet
  5. 什么是Spring MVC框架的控制器?
  6. Spring MVC的控制器是不是单例模式,如果是,有什么问题,怎么解决?
  7. 请描述Spring MVC的工作流程?描述一下 DispatcherServlet 的工作流程?
  8. MVC是什么?MVC设计模式的好处有哪些
  9. 注解原理是什么
  10. Spring MVC常用的注解有哪些?
  11. SpingMvc中的控制器的注解一般用哪个,有没有别的注解可以替代?
  12. @Controller注解的作用
  13. @RequestMapping注解的作用
  14. @ResponseBody注解的作用
  15. @PathVariable和@RequestParam的区别
  16. Spring MVC与Struts2区别
  17. Spring MVC怎么样设定重定向和转发的?
  18. Spring MVC怎么和AJAX相互调用的?
  19. 如何解决POST请求中文乱码问题,GET的又如何处理呢?
  20. Spring MVC的异常处理?
  21. 如果在拦截请求中,我想拦截get方式提交的方法,怎么配置
  22. 怎样在方法里面得到Request,或者Session?
  23. 如果想在拦截的方法里面得到从前台传入的参数,怎么得到?
  24. 如果前台有很多个参数传入,并且这些参数都是一个对象的,那么怎么样快速得到这个对象?
  25. Spring MVC中函数的返回值是什么?
  26. Spring MVC用什么对象从后台向前台传递数据的?
  27. 怎么样把ModelMap里面的数据放入Session里面?
  28. Spring MVC里面拦截器是怎么写的
  29. 介绍一下 WebApplicationContext

SpringBoot

  1. 什么是 Spring Boot?
  2. Spring Boot 有哪些优点?
  3. Spring Boot 的核心注解是哪个?它主要由哪几个注解组成的?
  4. 什么是 JavaConfig?
  5. Spring Boot 自动配置原理是什么?
  6. 你如何理解 Spring Boot 配置加载顺序?
  7. 什么是 YAML?
  8. YAML 配置的优势在哪里 ?
  9. Spring Boot 是否可以使用 XML 配置 ?
  10. spring boot 核心配置文件是什么?bootstrap.properties 和 application.properties 有何区别 ?
  11. 什么是 Spring Profiles?
  12. 如何在自定义端口上运行 Spring Boot 应用程序?
  13. 如何实现 Spring Boot 应用程序的安全性?
  14. 比较一下 Spring Security 和 Shiro 各自的优缺点 ?
  15. Spring Boot 中如何解决跨域问题 ?
  16. 什么是 CSRF ***?
  17. Spring Boot 中的监视器是什么?
  18. 如何在 Spring Boot 中禁用 Actuator 端点安全性?
  19. 我们如何监视所有 Spring Boot 微服务?
  20. 什么是 WebSockets?
  21. 什么是 Spring Data ?
  22. 什么是 Spring Batch?
  23. 什么是 FreeMarker 模板?
  24. 如何集成 Spring Boot 和 ActiveMQ?
  25. 什么是 Apache Kafka?
  26. 什么是 Swagger?你用 Spring Boot 实现了它吗?
  27. 前后端分离,如何维护接口文档 ?
  28. 如何重新加载 Spring Boot 上的更改,而无需重新启动服务器?Spring Boot项目如何热部署?
  29. 您使用了哪些 starter maven 依赖项?
  30. Spring Boot 中的 starter 到底是什么 ?
  31. spring-boot-starter-parent 有什么用 ?
  32. Spring Boot 打成的 jar 和普通的 jar 有什么区别 ?
  33. 运行 Spring Boot 有哪几种方式?
  34. Spring Boot 需要独立的容器运行吗?
  35. 开启 Spring Boot 特性有哪几种方式?
  36. 如何使用 Spring Boot 实现异常处理?
  37. 如何使用 Spring Boot 实现分页和排序?
  38. 微服务中如何实现 session 共享 ?
  39. Spring Boot 中如何实现定时任务 ?

Spring Cloud

  1. 为什么需要学习Spring Cloud
  2. 什么是Spring Cloud
  3. 设计目标与优缺点
  4. 设计目标
  5. 优缺点
  6. Spring Cloud发展前景
  7. 整体架构
  8. 主要项目
  9. Spring Cloud Config
  10. Spring Cloud Netflix
  11. Spring Cloud Bus
  12. Spring Cloud Consul
  13. Spring Cloud Security
  14. Spring Cloud Sleuth
  15. Spring Cloud Stream
  16. Spring Cloud Task
  17. Spring Cloud Zookeeper
  18. Spring Cloud Gateway
  19. Spring Cloud OpenFeign
  20. Spring Cloud的版本关系
  21. Spring Cloud和SpringBoot版本对应关系
  22. Spring Cloud和各子项目版本对应关系
  23. SpringBoot和SpringCloud的区别?
  24. 使用 Spring Boot 开发分布式微服务时,我们面临以下问题
  25. 服务注册和发现是什么意思?Spring Cloud 如何实现?
  26. Spring Cloud 和dubbo区别?
  27. 负载平衡的意义什么?
  28. 什么是 Hystrix?它如何实现容错?
  29. 什么是 Hystrix 断路器?我们需要它吗?
  30. 什么是 Netflix Feign?它的优点是什么?
  31. 什么是 Spring Cloud Bus?我们需要它吗?
  32. Spring Cloud断路器的作用
  33. 什么是Spring Cloud Config?
  34. 什么是Spring Cloud Gateway?

MyBatis

  1. MyBatis是什么?
  2. ORM是什么
  3. 为什么说Mybatis是半自动ORM映射工具?它与全自动的区别在哪里?
  4. 传统JDBC开发存在的问题
  5. JDBC编程有哪些不足之处,MyBatis是如何解决这些问题的?
  6. Mybatis优缺点
  7. MyBatis框架适用场景
  8. Hibernate 和 MyBatis 的区别
  9. MyBatis的解析和运行原理
  10. MyBatis编程步骤是什么样的?
  11. 请说说MyBatis的工作原理
  12. MyBatis的功能架构是怎样的
  13. MyBatis的框架架构设计是怎么样的
  14. Mybatis都有哪些Executor执行器?它们之间的区别是什么?
  15. Mybatis中如何指定使用哪一种Executor执行器?
  16. Mybatis是否支持延迟加载?如果支持,它的实现原理是什么?
  17. #{}和${}的区别
  18. 模糊查询like语句该怎么写
  19. 在mapper中如何传递多个参数
  20. Mybatis如何执行批量操作
  21. 如何获取生成的主键
  22. 当实体类中的属性名和表中的字段名不一样 ,怎么办
  23. Mapper 编写有哪几种方式?
  24. 什么是MyBatis的接口绑定?有哪些实现方式?
  25. 使用MyBatis的mapper接口调用时有哪些要求?
  26. 最佳实践中,通常一个Xml映射文件,都会写一个Dao接口与之对应,请问,这个Dao接口的工作原理是什么?Dao接口里的方法,参数不同时,方法能重载吗
  27. Mybatis的Xml映射文件中,不同的Xml映射文件,id是否可以重复?
  28. 简述Mybatis的Xml映射文件和Mybatis内部数据结构之间的映射关系?
  29. Mybatis是如何将sql执行结果封装为目标对象并返回的?都有哪些映射形式?
  30. Xml映射文件中,除了常见的select|insert|updae|delete标签之外,还有哪些标签?
  31. Mybatis映射文件中,如果A标签通过include引用了B标签的内容,请问,B标签能否定义在A标签的后面,还是说必须定义在A标签的前面?
  32. MyBatis实现一对一,一对多有几种方式,怎么操作的?
  33. Mybatis是否可以映射Enum枚举类?
  34. Mybatis动态sql是做什么的?都有哪些动态sql?能简述一下动态sql的执行原理不?
  35. Mybatis是如何进行分页的?分页插件的原理是什么?
  36. 简述Mybatis的插件运行原理,以及如何编写一个插件。
  37. Mybatis的一级、二级缓存

Redis

  1. 什么是Redis
  2. Redis有哪些优缺点
  3. 为什么要用 Redis /为什么要用缓存
  4. 为什么要用 Redis 而不用 map/guava 做缓存?
  5. Redis为什么这么快
  6. Redis有哪些数据类型
  7. Redis的应用场景
  8. 什么是Redis持久化?
  9. Redis 的持久化机制是什么?各自的优缺点?
  10. 如何选择合适的持久化方式
  11. Redis持久化数据和缓存怎么做扩容?
  12. Redis的过期键的删除策略
  13. Redis key的过期时间和永久有效分别怎么设置?
  14. 我们知道通过expire来设置key 的过期时间,那么对过期的数据怎么处理呢?
  15. MySQL里有2000w数据,redis中只存20w的数据,如何保证redis中的数据都是热点数据
  16. Redis的内存淘汰策略有哪些
  17. Redis主要消耗什么物理资源?
  18. Redis的内存用完了会发生什么?
  19. Redis如何做内存优化?
  20. Redis线程模型
  21. 什么是事务?
  22. Redis事务的概念
  23. Redis事务的三个阶段
  24. Redis事务相关命令
  25. 事务管理(ACID)概述
  26. Redis事务支持隔离性吗
  27. Redis事务保证原子性吗,支持回滚吗
  28. Redis事务其他实现
  29. 哨兵模式
  30. 官方Redis Cluster 方案(服务端路由查询)
  31. 基于客户端分配
  32. 基于代理服务器分片
  33. Redis 主从架构
  34. Redis集群的主从复制模型是怎样的?
  35. 生产环境中的 redis 是怎么部署的?
  36. 说说Redis哈希槽的概念?
  37. Redis集群会有写操作丢失吗?为什么?
  38. Redis集群之间是如何复制的?
  39. Redis集群最大节点个数是多少?
  40. Redis集群如何选择数据库?
  41. Redis是单线程的,如何提高多核CPU的利用率?
  42. 为什么要做Redis分区?
  43. 你知道有哪些Redis分区实现方案?
  44. Redis分区有什么缺点?
  45. Redis实现分布式锁
  46. 如何解决 Redis 的并发竞争 Key 问题
  47. 分布式Redis是前期做还是后期规模上来了再做好?为什么?
  48. 什么是 RedLock
  49. 缓存雪崩
  50. 缓存穿透
  51. 缓存击穿
  52. 缓存预热
  53. 缓存降级
  54. 热点数据和冷数据
  55. 缓存热点key
  56. Redis支持的Java客户端都有哪些?官方推荐用哪个?
  57. Redis和Redisson有什么关系?
  58. Jedis与Redisson对比有什么优缺点?
  59. Redis与Memcached的区别
  60. 如何保证缓存与数据库双写时的数据一致性?
  61. Redis常见性能问题和解决方案?
  62. Redis官方为什么不提供Windows版本?
  63. 一个字符串类型的值能存储最大容量是多少?
  64. Redis如何做大量数据插入?
  65. 假如Redis里面有1亿个key,其中有10w个key是以某个固定的已知的前缀开头的,如果将它们全部找出来?
  66. 使用Redis做过异步队列吗,是如何实现的
  67. Redis如何实现延时队列
  68. Redis回收进程如何工作的?
  69. Redis回收使用的是什么算法?

附答案解析

Dubbo

  1. 为什么要用 Dubbo?
  2. Dubbo 是什么?
  3. Dubbo 的使用场景有哪些?
  4. Dubbo 核心功能有哪些?
  5. Dubbo 核心组件有哪些?
  6. Dubbo 服务器注册与发现的流程?
  7. Dubbo 的整体架构设计有哪些分层?
  8. Dubbo Monitor 实现原理?
  9. Dubbo 类似的分布式框架还有哪些?
  10. Dubbo 和 Spring Cloud 有什么关系?
  11. Dubbo 和 Spring Cloud 有什么哪些区别?
  12. Dubbo 和 Dubbox 之间的区别?
  13. Dubbo 有哪些注册中心?
  14. Dubbo 的注册中心集群挂掉,发布者和订阅者之间还能通信么?
  15. Dubbo集群提供了哪些负载均衡策略?
  16. Dubbo的集群容错方案有哪些?
  17. Dubbo 配置文件是如何加载到 Spring 中的?
  18. 说说核心的配置有哪些?
  19. Dubbo 超时设置有哪些方式?
  20. 服务调用超时会怎么样?
  21. Dubbo 使用的是什么通信框架?
  22. Dubbo 支持哪些协议,它们的优缺点有哪些?
  23. Dubbo 用到哪些设计模式?
  24. 服务上线怎么兼容旧版本?
  25. Dubbo telnet 命令能做什么?
  26. Dubbo 支持服务降级吗?
  27. Dubbo 如何优雅停机?
  28. Dubbo SPI 和 Java SPI 区别?
  29. Dubbo 支持分布式事务吗?
  30. Dubbo 可以对结果进行缓存吗?
  31. Dubbo 必须依赖的包有哪些?
  32. Dubbo 支持哪些序列化方式?
  33. Dubbo 在安全方面有哪些措施?
  34. 服务调用是阻塞的吗?
  35. 服务提供者能实现失效踢出是什么原理?
  36. 同一个服务多个注册的情况下可以直连某一个服务吗?
  37. Dubbo 服务降级,失败重试怎么做?
  38. Dubbo 使用过程中都遇到了些什么问题?
  39. 为什么要有RPC
  40. 什么是RPC
  41. PRC架构组件
  42. RPC和SOA、SOAP、REST的区别
  43. RPC框架需要解决的问题?
  44. RPC的实现基础?
  45. RPC使用了哪些关键技术?
  46. 主流RPC框架有哪些
  47. RPC的实现原理架构图

Tomcat

  1. Tomcat是什么?
  2. Tomcat的缺省端口是多少,怎么修改
  3. tomcat 有哪几种Connector 运行模式(优化)?
  4. Tomcat有几种部署方式?
  5. tomcat容器是如何创建servlet类实例?用到了什么原理?
  6. Tomcat工作模式
  7. Tomcat顶层架构
  8. Tomcat顶层架构小结
  9. Connector和Container的微妙关系
  10. Container架构分析
  11. Container如何处理请求的

ZooKeeper

  1. ZooKeeper 是什么?
  2. ZooKeeper 提供了什么?
  3. Zookeeper 文件系统
  4. Zookeeper 怎么保证主从节点的状态同步?
  5. 四种类型的数据节点 Znode
  6. Zookeeper Watcher 机制 -- 数据变更通知
  7. 客户端注册 Watcher 实现
  8. 服务端处理 Watcher 实现
  9. 客户端回调 Watcher
  10. ACL 权限控制机制
  11. Chroot 特性
  12. 会话管理
  13. 服务器角色
  14. Zookeeper 下 Server 工作状态
  15. 数据同步
  16. zookeeper 是如何保证事务的顺序一致性的?
  17. 分布式集群中为什么会有 Master主节点?
  18. zk 节点宕机如何处理?
  19. zookeeper 负载均衡和 nginx 负载均衡区别
  20. Zookeeper 有哪几种几种部署模式?
  21. 集群最少要几台机器,集群规则是怎样的?集群中有 3 台服务器,其中一个节点宕机,这个时候 Zookeeper 还可以使用吗?
  22. 集群支持动态添加机器吗?
  23. Zookeeper 对节点的 watch 监听通知是永久的吗?为什么不是永久的?
  24. Zookeeper 的 java 客户端都有哪些?
  25. chubby 是什么,和 zookeeper 比你怎么看?
  26. 说几个 zookeeper 常用的命令。
  27. ZAB 和 Paxos 算法的联系与区别?
  28. Zookeeper 的典型应用场景
  29. Zookeeper 都有哪些功能?
  30. 说一下 Zookeeper 的通知机制?
  31. Zookeeper 和 Dubbo 的关系?

Netty

  1. Netty 是什么?
  2. Netty 的特点是什么?
  3. Netty 的优势有哪些?
  4. Netty 的应用场景有哪些?
  5. Netty 高性能表现在哪些方面?
  6. BIO、NIO和AIO的区别?
  7. NIO的组成?
  8. Netty的线程模型?
  9. TCP 粘包/拆包的原因及解决方法?
  10. 什么是 Netty 的零拷贝?
  11. Netty 中有哪种重要组件?
  12. Netty 发送消息有几种方式?
  13. 默认情况 Netty 起多少线程?何时启动?
  14. 了解哪几种序列化协议?
  15. 如何选择序列化协议?
  16. Netty 支持哪些心跳类型设置?
  17. Netty 和 Tomcat 的区别?
  18. NIOEventLoopGroup源码?
  19. JDK原生NIO程序的问题
  20. Netty的特点
  21. Netty常见使用场景
  22. I/O模型
  23. 阻塞I/O
  24. I/O复用模型
  25. 基于buffer
  26. 线程模型
  27. 事件驱动模型
  28. Reactor线程模型
  29. Netty线程模型
  30. 异步处理
  31. Bootstrap、ServerBootstrap
  32. Future、ChannelFuture
  33. Channel
  34. Selector
  35. NioEventLoop
  36. NioEventLoopGroup
  37. ChannelHandler
  38. ChannelHandlerContext
  39. ChannelPipline

总结

小编整理Java面试宝典分享给大家复习,Java核心知识283页覆盖了JVM、锁、并发、Java反射、Spring原理、微服务、Zookeeper、数据库、数据结构等大量知识点,如果需要获取到这个【核心知识点整理】文档的话关注点赞,搜微信公众号:麒麟改bug获取。