其他分享
首页 > 其他分享> > 大厂面经:三非背景、6轮面试,终获阿里Offer!

大厂面经:三非背景、6轮面试,终获阿里Offer!

作者:互联网

这是一个励志读者在收获阿里 Offer 后的复盘,他积极准备了 1 年时间,梦想总算照进现实,希望这份面经总结能给你带来帮助和启发。


大家好!本人网名:茶杯,三非背景(非985 / 非211 / 非理工科) ,工作 5 年时间,待了三家公司,去阿里一直是我的梦想。

为了能进阿里,我给自己制定了非常详细的学习计划:Java Core、JVM、网络、Spring 源码、MySQL、Redis、MQ、Netty,整整准备了 1 年时间。

在面了几家还算知名的大厂后,我总结了一波面试套路,就开始了阿里的面试之旅。 最终 , 历经 6 轮面试,顺利拿到了 阿里的 offe r , 也算是圆梦了。

一 路走来, 要 感谢的人太多。 下面, 我 对整个 面试过程做一次复盘 ,希望给大家一些 启发。


01 第一轮技术面:阿里P6面试官

1、看你简历中提到处理过多次 JVM 故障,可以讲讲你遇到过哪些 OOM 的案例么?

a、我分别把之前工作中遇到的堆空间、元空间、堆外内存 OOM 场景都讲了一遍

b、按照如何分析、如何排查、如何解决、事后如何防范这个思路进行

2、看你简历写做了线程池调优,能讲下线程池的原理以及做了哪些优化吗?

a、业务线程池相互隔离

b、根据CPU核数、线程池任务的 IO 耗时/计算耗时,设置合理的核心线程数,提升性能

c、动态修改线程池参数,方便维护

d、重写拒绝策略,保证任务不丢

e、聊了一下线程池源码里的一些细节

3、能讲下你对 MySQL MVCC 的理解吗?

我分别讲了一下 RR 和 RC 隔离级别的实现原理有哪些不同

4、MySQL 索引是怎么实现的?

a、分别从性能和实现上讲了数组、链表、Hash、二叉树、BTree 为什么不合适

b、详细讲了 B+ Tree 的实现,以及普通索引是如何查找数据的

c、中间提到了节点大小、IO、回表、覆盖索引等概念

5、讲讲 Redis 是怎么用的?

a、讲了分布式锁原理

b、讲了 Redis String 的底层实现

c、讲了 Redis ZSet 的实现,详细讲了跳表结合 Hash 是如何提升效率的

6、RecketMQ 的消息堆积如何解决?

a、Producer 端:上游发消息速度过快,可以减少消息的发送频率

b、Consumer端:下游消费不过来,可以扩容来提高消费速度

c、Broker 端:内存是否够大?如果 Page Cache 够大的话,可以提高 Consumer 拉消息的性能

一面小结:

当我答完第一个 JVM 问题时,面试官就说这轮我过了,说我这块研究很深入。

所以,我觉得面试技巧很重要。面试前我就考虑到了如何展现自己的优势,在自我介绍时就会把自己擅长的部分说出来。

另外,一般一面考察的点有:JVM、JDK 并发包/集合类、Redis、MySQL、MQ、RPC。


02 第二轮技术面:阿里P7面试官

阿里二面问的技术问题并不是很多,更多的是问业务场景和解决方案。

后来私底下问一面面试官,他说因为一面已经全方面考察技术了,所以认为我技术方面是 OK 的,就不会作为主要的考察方向。

1、讲下项目里的限流策略怎么做的?

a、用 Redis 做的分布式限流

b、滑动窗口/漏斗/令牌桶,三种限流算法对比

c、解释了下为什么没有用其他限流组件

2、讲下简历中的秒杀项目怎么做的?

a、CDN:静态数据缓存

b、缓存:上层抗住流量

c、限流:防止应用挂掉

d、答题验证码:削峰

e、MQ:异步/削峰/解耦

f、风控、接口幂等:防刷

g、分库分表:减轻 DB 压力

3、如果 Redis 挂了一台怎么办?

4、如果 RocketMQ 挂了怎么办?

5、RocketMQ 重复消费了怎么办?

6、RocketMQ 为什么会重复消费?讲下 RocketMQ 造成重复消费的底层实现原理?

7、MQ 会丢消息吗?如何保证不丢?

8、问了很多业务方面的细节

9、在阿里伯乐系统,手写算法题

10、问了下面试官具体的工作内容和团队氛围

二面小结:

项目以及业务都会深入考察,这块一定要好好准备,一面过的人很多,二面挂的人很多。

二面一般都是入职后带你的师兄,如果你业务不精通技术好也不一定能过,因为终究还是要干活的。


03 第三轮技术面:阿里P8面试官

主管面考察的范围就更广了:

1、讲下在团队里的角色

2、讲下之前的经历

3、讲下近期做的比较核心的工作(二面项目有关的东西又讲了一遍)

4、讲下有哪些做得好和做得不好的地方?

5、如果流量放大 10倍,100倍怎么办?

6、分库分表怎么做的,讲下数据迁移方案

7、讲一下你做的 JVM 调优

8、聊一下 Redis 性能问题

9、面试官讲了一下团队的业务情况,以及进去后可能要做的具体工作

三面小结:

还是以项目为主,但问题会更深入。上面大部分问题,我都花了很多心思总结,汇总到了自己的笔记里,而且面试前反复看过很多次,从而保证我在面试过程中能够讲清楚细节。


04 第四轮交叉面:阿里P8面试官

主管级别的交叉面,也是一个 P8 面试官。

我也不知道为什么会有这一轮,问的问题跟 2 面、3 面差不多,这里就不展开了。


05 第五轮技术面:阿里P9面试官

1、介绍工作经历

2、介绍项目以及项目里的角色

3、讲下项目中遇到的困难是如何解决的

4、一道实际需求的设计题:高并发场景,当用户下单(20元)时,会提示用户花 10 元买一个会员,同时送 4 张 6 元的优惠券,本次就可以使用。该接口如何实现?需要考虑各方失败的情况

最后一道设计题,我和面试官讨论了将近 30 分钟,主要考查高并发场景下的设计能力。

面试官会关注:设计方案的合理性以及完整性,如果某个环节出问题了怎么保证高可用?会不会有丢数据的风险?数据一致性怎么保障?如果流量很大性能如何保证?

五面小结:

主要考察设计能力以及对项目的整体把握,不但宏观层面要做好架构设计,细节上的实现也会死抠到底。

不论是技术的深度和广度,甚至临场分析问题、解决问题的能力都有考察,这些都需要平时的技术积累。


06 第六轮HR面

1、介绍履历背景

2、介绍工作内容以及承担的角色

3、谈谈项目里的高并发场景怎么解决的

4、推进项目的过程中遇到了问题怎么办

5、同事怎么评价你

六面小结:

主要考察的是思考能力和思维方式、沟通、协作、配合团队、做事结果导向等能力。另外,阿里 HR 也是会问技术问题的。


个人感悟

1、基础一定要扎实

基础不牢地动山摇,这一年的准备,基础知识通过查漏补缺提升了很多。但也发现了诸多不足,未来还需继续积累。

2、养成良好的习惯,坚持学习

开发这行内卷太严重了,年轻的时候一定要养成学习的习惯。如果在小公司做的是没挑战的事情,还忙得没时间学习,建议趁早换一份能带来成长的工作。

3、给自己定一个目标

做事情一定要定一个目标,只要你信念够强,它就会一直指引着你前进。

不然经历过一天疲惫的工作后,下班再继续学习这件事是坚持不下来的。

4、给自己制定详细的学习计划

两个月啃下一个主流技术栈,1 年下来差不多也能啃完 6 块硬骨头,这将是你未来面试的兵器库,十八般武艺不说样样精通,随便挑几个跟面试官捞一个小时应该不在话下!

5、梦想并非遥不可及

我一直把进阿里当做自己的梦想,这五年来一步一个脚印,中间不曾有过任何一次放弃。

刚毕业那会,被无数家公司拒绝过,但这并没有劝退我,感谢当时鼓励我的同学。

工作几年后,也被资深同事嘲讽我不知天高地厚,但这并没有劝退我,感谢当时劝我用最高标准要求自己、并相信自己的网友。

在不断提升自己技术深度的过程中,各种深不可测的源码、框架让我抓狂,但这也没有劝退我,感谢每个指点过我的老师。

最后,感谢一路走来所有帮助过我的朋友们!祝大家都有一个美好的未来!


- End -


作者简介:985硕士,前亚马逊工程师,现58转转技术总监

欢迎扫描下方的二维码,关注我的个人公众号:武哥漫谈IT,精彩原创不断!

标签:面试官,三非,面经,Redis,终获,面试,阿里,线程,讲下
来源: https://www.cnblogs.com/luojunwu/p/14700079.html