首发!首发!首发!彭同学认真总结的超详细字节动车帝后端面经!

没有录音,纯靠印象回忆的,所以可能漏了点问题。

一. 投递简历(6月17号)

 

二. 约面(6月18号)

不得不说字节跳动的效率还是很高的,投简历后第二天晚上就接到了HR小姐姐约一面的电话。约到了隔天晚上。

 

 

 

三. 一面(6月19号)

- 自我介绍,巴拉巴拉吹了一通自己Java怎么样,结果面试官说Java不招人了,他们这个部门主要用Go和Python开发。

- Java中HashTable、HashMap、ConcurrentHashMap的区别?ConcurrentHashMap是怎么实现线程安全的?

面试官还是先问了个Java基础题,不过后面就再也没问过Java相关的了。

- 讲一下TCP的三次握手和四次挥手?为什么要有TIME_WAIT阶段?为什么握手是三次挥手是四次?

- 因为我的项目用了Websocket,问了一下Websocket的特点

- 知道HTTP长连接吗?为什么用Websocket不用HTTP?

- Redis有哪些数据结构?用过哪些?

- 用过setnx吗?(我说我没用过,但知道可以实现分布式锁)

- Redis key要设置过期时间吗?为什么?

- 用Redis实现排行榜可以使用什么数据结构?(Zset)

- cookie和session的区别

- 事务的四个隔离级别?MySQL InnoDB默认的是啥?

- 知道联合索引吗?给了个情景模拟,问是否会用到索引(最左前缀原则)

- 聚簇索引和非聚簇索引有什么区别?InnoDB属于哪种?(这个我一直以为非聚簇索引就是辅助索引,就说InnoDB两种都有,后来复盘的时候才知道,非聚簇索引是MyISAM相对InnoDB而言的,InnoDB数据和索引放在同一个文件中,MyISAM不是)

- 两道算法题:

1. leetcode102-二叉树的层序遍历&leetcode103-二叉树的锯齿形层次遍历

层序遍历用BFS,锯齿形层次遍历可以用两个栈。

2. leetcode141-环形链表

快慢指针

- 反问环节

一面问的问题都不难,可能是我运气比较好。

一面过了不久就接到HR小姐姐的电话,说可以准备待会的二面了。(同一天晚上)

 

 

四. 二面(6月19号)

 

二面主要是围绕着做过的项目来问的,并且情景模拟题问得多。

 

- 自我介绍

- 介绍一下你的两个项目

- 项目用了Websocket,为什么要用Websocket,解决了什么问题?

- 如果把这个项目引申到多机(分布式)上会有什么问题?

- 如果要实现一个Websocket聊天室,应该怎么设计?如果用多机会有什么问题,如何解决?

我答的是:服务器之间共享一下连接的用户列表,一台服务器收到信息后将消息发给其他服务器,让其他服务器帮忙转发给自己所连接的用户。

- 因为我把项目部署到服务器上了,面试官问:介绍一下从输入网址到进入网站经历了哪些过程?面试官明显看出我使用了Nginx反向代理了多端口服务,但是我忘了说,然后就开始引导我说了出来。

- 为什么要使用反向代理?(1. 代理到常用的HTTPS端口 2. 解决跨域问题)

- HTTP状态码500 502 504的含义?(这个我500记岔了)如果反向代理上游服务器没写端口,是502还是504?(我也回答错了,只要无法建立连接都是504 Gateway Timeout,502必是收到了响应)

- 状态码499听说过没?(说没有,后来了解到这是Nginx自己定义的)

- Nginx的特点(我说除了反向代理还有负载均衡,支持很多负载均衡的策略,然后赶紧说我对Nginx其实也不是很熟,求求面试官别追问下去了。。)

- 当访问一个后端接口很久还没有收到响应,如何排查?

- TCP UDP的区别

- 你做过什么MySQL调优?(解释了一下只是了解一些理论,并没有实际调优过)

- 给了几条SQL语句,问会不会用到索引(最左前缀原则和索引失效的一些情况)

- 怎么看SQL的执行计划(explain)

- 因为另一个项目中用了OpenResty,问OpenResty和Nginx的区别?(调用lua脚本)

- 项目里用Redis做什么?用的哪种数据类型?(我还多嘴提了一下可以用来做令牌桶限流,然后因为不是很熟面试官追问了一下就赶紧投降了)

- Redis持久化机制介绍一下

- 消息队列为什么选择RabbitMQ?还了解其他消息队列吗?比较一下RabbitMQ和它们之间的区别?

- 消息队列你用来干什么?可以用来干什么?(解耦、异步、削峰填谷、分布式事务)

- linux命令

1. 在一个目录下查找一个文件用什么命令?(find)

2. 查看正在系统正在监听中的端口用什么命令(netstat)

3. 一个日志文件,第二列是用户的访问IP,列与列之间用空格隔开,问统计出现最多的IP地址可以用哪些命令的组合?(cat读文件,sort+uniq用于排序,cut或awk用于获取第二列的文本,head用于获取排序后的第一行)

- 进程间通信的方法有哪些?

- 多路复用 select poll epoll的区别?

- 两道算法题:

1. leetcode440-字典序的第K小数字(困难题,据说是字节的常考算法题,说了一下思路,没做出来)

2. leetcode53-最大子序和(前缀和,秒了)

- 反问环节

二面完之后因为已经很晚了,面试官就叫我等通知,不会继续三面了。

 

 

五. 三面约面(6月21号)

 

20号是星期六,HR可能不上班,隔了一天,21号上午打电话来约三面,约了23号晚上

 

六. 三面(6月23号)

三面的面试官很严肃。。应该是Leader,做的项目被怼了个体无完肤。

- 自我介绍

- 能实习多久

- 你的项目的难点是什么?

- 项目中Docker的使用,有没有优化的空间?

- 为什么用Websocket?为什么不用HTTP?(这个真的是每一面都问到了!我说了我认为的解决了的问题,前两面的面试官都没什么反应,但是三面这个面试官看起来不是很满意,说这不是关键)

- Netty的原理?(NIO)

- NIO的原理?(Java的实现方式是Windows:select、Linux系:epoll、MacOS:kqueue)

- Netty中有多线程吗?(workerGroup,bossGroup)

- epoll的原理?(二面之后正好补了一下epoll的原理,回答了个大概)

- 有关注过什么开源项目吗?

- 为什么用RabbitMQ?它的优缺点?(和二面问题大致上重了,我就顺便拓展地说了一下AMQP协议的一些概念)

- 我们部门使用的是Go/Python,你觉得你能跟得上吗?

- 反问环节

 

三面时间很短,也没问算法题,可能是leader的时间比较值钱,差点以为我挂了。。面试完不久接到HR小姐姐的电话面,感觉HR面应该不太会挂人。。只要说话好听一点就行了,面完后第二天早上收到了口头offer。

面试感受:

字节跳动效率挺高的,基础知识+项目经历很重要,本来特地复习了很多Java、JVM、Java多线程相关的知识,结果都没问到

仅做分享,如有侵权,联系删除。

 

首发!首发!首发!彭同学认真总结的超详细字节动车帝后端面经!

                            公众号后台回复:【cs字节21届提前批】即可领取

 

首发!首发!首发!彭同学认真总结的超详细字节动车帝后端面经!

                            公众号后台回复:【cs猿辅导】即可领取

想要获取更多高质量,详细,精选,分类,整理,精装的所有互联网公司的面试真题,在此文末点赞评论:【某某岗位面经合集】,我看到后直接私信给链接。或者扫描博客左侧二维码,扫描它,然后带走我,你想要的互联网大厂各个岗位面试真题我全都有。

 

互联网校招面经,只专注高质量互联网初级面试经验分享。互联网初级面试真题小经是最专业的!致力于为广大初入互联网行业的求职者精心整理,免费分享面试相关资源。

辛苦整理不易,点个赞收藏吧,听说点赞的同学都像下图这样offer满满

首发!首发!首发!彭同学认真总结的超详细字节动车帝后端面经!