首页 > 字节跳动后台开发日常实习1~3面经,已offer
头像
百道
编辑于 2020-07-01 11:05
+ 关注

字节跳动后台开发日常实习1~3面经,已offer

部门:懂车帝
本人:某不知名211计算机专业本科

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

投递简历(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不是)
  • 两道算法题:
    • leetcode102-二叉树的层序遍历&leetcode103-二叉树的锯齿形层次遍历
      层序遍历用BFS,锯齿形层次遍历可以用两个栈。
    • 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命令
    • 在一个目录下查找一个文件用什么命令?(find)
    • 查看正在系统正在监听中的端口用什么命令(netstat、grep)
    • 一个日志文件,第二列是用户的访问IP,列与列之间用空格隔开,问统计出现最多的IP地址用哪些命令的组合?(cat读文件,sort+uniq用于排序,cut或awk用于获取第二列的文本,head用于获取排序后的第一行)
  • 进程间通信的方法有哪些?
  • 多路复用 select poll epoll的区别?
  • 两道算法题:
    • leetcode440-字典序的第K小数字(困难题,据说是字节的常考算法题,说了一下思路,没做出来)
    • 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多线程相关的知识,结果都没问到😂

更多模拟面试

全部评论

(11) 回帖
加载中...
话题 回帖

相关热帖

历年真题 真题热练榜 24小时
技术(软件)/信息技术类
查看全部

热门推荐