双非本科,软件工程,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等等。机会永远是留给有准备的人。

点击此处免费获取文档



Java基础


Java 集合框架


jvm


多线程


网络


算法和数据结构


Spring


Netty


微服务/分布式


消息队列


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


MySQL


Redis


经验总结

这是我在工作、面试中学习并总结到的一些知识点,都是一些比较典型的、常被问到的问题。如果你平时没有注意去总结的话,那么当你面试被问到的时候可能会是一脸懵圈,就算这个问题你知道怎么回事,但是你平时没有认真总结,你也可能会出现逻辑混乱的情况,从而错失工作机会。

有些知识点不经常使用就会忘记,但是面试还会问,对此,我也是深受其害,所以我决定将这些遇见的问题整理下来,分享出去,帮助更多的人,我们共同进步。所谓“温故而知新”,没事的时候多翻看一下这些知识