写点什么

阿里巴巴 2021 年最新最全 500 道 Java 后端面试大全(值得收藏)

用户头像
周老师
关注
发布于: 18 小时前

进大厂是大部分程序员的梦想,而进大厂的门槛也是比较高的,所以这里整理了一份阿里、美团、滴滴、头条等大厂面试大全其中概括的知识点有:Java 基础、spring、springmvc、springboot、springcloud、JVM、Tomcat、dubbo、netty、zookeeper 共有 500+道面试题

面试题整理十分全面,文末还有答案解析!(文章比较长,耐心看完,让你面试提升一大截!)


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. 日志

Java 基础 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 调优的参数都有哪些?

JVM 40 道面试答案


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. 有几种不同类型的自动代理?

Spring 80 道面试题答案


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

SpringMVC 30 道面试答案


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 中如何实现定时任务 ?

SpringBoot 40 道面试答案


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?

SpringCloud 34 道面试答案


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 的一级、二级缓存

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 回收使用的是什么算法?

Redis 70 道面试答案解析


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 的实现原理架构图

Dubbo 面试答案


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 如何处理请求的

Tomcat 面试答案


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 的关系?

Zookeeper 面试答案


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

Netty 面试答案


面试答案汇总


小编整理 Java 面试宝典分享给大家复习

Java 核心知识 283 页覆盖了 JVM、锁、并发、Java 反射、Spring 原理、微服务、Zookeeper、数据库、数据结构等大量知识点







欢迎大家扫码来关注公众号博主,获取文章全部资料,此公众号会持续更新技术干货、不定期分享 Java 进阶面试宝典、Java 核心知识、架构书籍电子版


用户头像

周老师

关注

精通java热衷于分享java领域资料,感谢支持 2020.06.09 加入

还未添加个人简介

评论

发布
暂无评论
阿里巴巴2021年最新最全500道Java后端面试大全(值得收藏)