两年经验双非,5 轮面试拿下阿里 Offer(面经原题复盘)
双非本科,软件工程,2 年工作经验。有幸得到内推机会,参加了阿里 Java 岗的面试。
为此我做了非常多的准备,最终顺利拿到 offer,特分享一下这次的 5 轮技术面真题,以及一份阿里 P7 师兄整理的 4 月份各部门面试题,希望能够给一些正在面试阿里或计划面试大厂的朋友提供帮助。

总共有五面,主要涉及的知识点复盘如下:
Java 部分
-
Jdk1.7 与 jdk1.8 在 g1 垃圾回收器上有什么区别?
-
常见的加载器有哪些,如何自定义一个加载器?
-
生产上有没有遇到 JVM 参数调优的问题?
-
知道什么是内存泄露吗,如何手动去造成内存泄露?
-
线程池常见的一些参数,知道 Future 接口吗?
数据库部分
-
常见的索引类型有哪些?
-
为什么主键索引使用 B+树而不去使用 B 树?
-
说一说联合索引最左原则的原理,并且什么情况下索引是生效的?为什么?
-
常见的隔离级别有哪些?有什么区别?
-
知道回表查询吗?聚集索引?
-
项目中有没有使用到分表分库?说一说怎么分的?
分布式/中间件部分
-
Redis 是单线程的吗?
-
为什么 Redis 的性能比较高?
-
使用消息队列有没有遇到消息丢失的情况,怎么去设计补偿行为?
-
说一说项目中为什么使用 Kafka 而不去使用其它消息队列?
-
说一说 Zookeeper 中的 Zab 协议
-
分布式锁的实现方案有哪些?各有哪些优势与缺点?
-
分布式限流 Sentinel 中线程模式与 QPS 模式的区别
微服务部分
-
有没有遇到 dubbo 连接数爆满的问题
-
dubbo 如何实现使用 zookeeper 找到对应的服务
-
dubbo 使用 zookeeper 作为分布式治理中心有什么弊端
-
说说你认为 dubbo 与 SpringCloud 的差异
总的来说,阿里的面试要做好充分的准备,面试官可能会让你介绍一下这个项目包括项目背景、项目架构、QPS 等等。机会永远是留给有准备的人。下面这套阿里 P7 师兄整理的 4 月份各部门面试题,分享给大家。每个知识点都有左侧导航书签页,看的时候十分方便,由于内容较多,这里就截取一部分图吧。需要的读者朋友们可以戳此传送门获取

Java 基础

Java 集合框架

jvm

多线程

网络

算法和数据结构

Spring

Netty

微服务/分布式

消息队列

分布式 ID,其他(网关、限流...)

MySQL

Redis

经验总结
这是我在工作、面试中学习并总结到的一些知识点,都是一些比较典型的、常被问到的问题。如果你平时没有注意去总结的话,那么当你面试被问到的时候可能会是一脸懵圈,就算这个问题你知道怎么回事,但是你平时没有认真总结,你也可能会出现逻辑混乱的情况,从而错失工作机会。
有些知识点不经常使用就会忘记,但是面试还会问,对此,我也是深受其害,所以我决定将这些遇见的问题整理下来,分享出去,帮助更多的人,我们共同进步。所谓“温故而知新”,没事的时候多翻看一下这些知识,没准就会有新的收获。你没时间整理的东西,我都帮你写好了。有需要的小伙伴可以戳此传送门获取