前言
双非渣硕,本以为简历都过不了...,还好字节能给一次机会。前阵子字节跳动的提前批开始了,看宣传是说有海量HC,机会多多,本着涨涨面经的心理,然后就投递了一下杭州那边的Data部门,首先在这里还要非常感谢内推我的小哥哥,非常热心的帮我跟踪进度,因为中间还出了一些小插曲(我投错部门了。。。),还是热心的小哥哥帮我联系HR,最后把我转到想要投递的部门了,我投的是java后端开发~面试项目大部分问题是围绕我的开源项目 蘑菇博客 展开的,还有就是我之前准备面试的一些 笔记(大佬请轻喷..)
注意:我投的是java后端开发~面试项目大部分问题是围绕我的开源项目 蘑菇博客 展开的,还有就是我之前准备面试的一些刷题笔记(大佬请轻喷..)> 有需要完整文档的【点击“这里”】便可~
面试时间
HR面完后,等了一个礼拜多,以为凉凉了,没想到收到惊喜,许愿成功~
- 第一天:第一面 + 第二面
- 等了两天:第三面 + HR面
- 过了一周后:等来了意向书
第一面
第一面我觉得应该是基础面,重点考察的是自己技术的广度 和一些技术的掌握情况,一面小哥哥也没有深究于某个特定的点,面试时间大约1个小时。
自我介绍
怎么打算投递后台岗位的,没有考虑契合自己研究方向的工作
有了解过OAuth2.0么,说说你对OAuth2.0的理解
对其它的一些博客框架有了解么,比如hexo
hexo和蘑菇博客相比有什么区别呢?蘑菇博客多了哪些功能和优势
RabbitMQ和其它消息队列,比如ActiveMQ,RocketMQ,Kafka有什么区别
有听过长尾效应么?你通过推荐字段设置的推荐等级,这样会让这些文章一直保持在较高的点击量,而且热度和点击量也不会随着时间而降低,有什么解决方案么?
我看到你有用到JustAuth这个登录授权?说说它会存在账号泄漏的问题么?
下面谈谈Redis,它会存在线程切换的问题么?
谈谈Redis单线程模型和IO多路复用
Redis的大Key的问题,如果有个Value的大小是2M,会有什么问题么?最大支持的Value大小是多少?
下面我们来做个题目吧?语言任意,选择喜欢的(ps:其实是leetCode原题,没有做过类似的,想了几分钟没有思路,哭。。,想问问思路,然后说换一题吧,那就,事后想想还挺简单的,根据第一位排序一下就好了)
# 给定一个数组,例如 [1,1,2,2,2,3,3,3,3]这样的,里面的数组不一定连续并且有序,假设我输入 2,这个2表示出现次数最高的两个
# 那么你需要给我返回 2,3
- 那就换个题目吧,看看下面这个题目,找数组出现次数最多的TOP N,回头听室友说,好像又是leetcode原题,泪目,算法能力太弱,没怎么刷题。
# 给定一个数组,例如 [1,1,2,2,2,3,3,3,3]这样的,里面的数组不一定连续并且有序,假设我输入 2,这个2表示出现次数最高的两个
# 那么你需要给我返回 2,3
然后我最开始的思路就是,通过hash存储出现的次数,然后key就是数组中出现的值。最后再对hash中的次数进行排序,最后得到top N,因为时间复杂度是O(N^2),问有没有优化思路,能否优化到O(N),想了半天没有想出来,没有充分运用以及构建好的hash表
后面面试官给讲了一下思路。从数组长度向下遍历进行查找
- 反问环节,问了问面试的表现,被告知算法能力比较薄弱,以为就此凉凉。。。然后一面说这边可以让你进入下一环节,这边大概需要等5到10分钟左右
第二面
二面考察的是技术深度面试,面试时间大约50分钟左右
- 自我介绍
- 博客已经开源了么,用的什么开源协议,博客的用户多么?
- 看你博客中用到了Solr和ElasticSearch,谈谈它们的原理,以及倒排索引?
- 对于Solr或者ES里面用到的一些中文分词器有了解过么?
- 谈谈那些技术栈,你比较熟悉的是那些,mysql 和redis?
- 聊聊MySQL的底层索引结构,InnoDB里面的B+Tree?
- B Tree 和 B+ Tree的区别
- 聊聊MySQL索引的发展过程?是一来就是B+Tree的么?从 没有索引、hash、二叉排序树、AVL树、B树、B+树 聊。
- 还有其它解决缓存穿透的方法么?布隆过滤器有了解过么?
- Redis中大面积的缓存失效,然后请求全部打到数据库,有什么解决方法?
- 如果出现一些热点数据,比如明星之间的新闻,造成大量的吃瓜用户涌入后台,但是服务器还没有缓存对应的数据,这样可能造成数据库宕机,如何避免这样的情况?
- 聊聊 JVM的组成结构?
# 链表的两两翻转 # 给定链表: 1->2->3->4->5->6->7 # 返回结果: 2->1->4->3->6->5->7
- 毕业时间是什么时候?现在面试的是实习岗位么?
- 反问环节:追问面试表现?告知 Redis这块掌握的还可以,但是MySQL这块显得不足。问后续的安排。
第三面
应该是Leader面,面试时间大概50分钟
- 自我介绍
- 好奇一下,用码云的人应该不多吧,为什么没有用Github?
- 你英文水平怎么样?
- 聊聊开源项目吧?我看这项目已经有800多赞了,你在这开源项目主要做了什么工作?
- 我们找些点来聊聊吧?先从ES和Solr开始,你们这两个都有在用么?
- SQL的方式实现搜索,你是怎么做的呢?
- 使用like匹配的时候,会不会查询非常慢呢?
- ES和Solr的底层都用了lunce,谈谈你对lunce的理解?
- 服务的注册和发现,其实依赖于一个注册中心的概念,会不会出现注册中心挂掉,而导致整个服务不可用,有没有什么好的解决方法呢?
- 有了解过Zookeeper整个的选举过程么?
- 谈谈Zookeeper的分布式一致性协议?
- 聊聊索引,我给你写个表,看看下面的查询语句,走了那些索引?
create table 'tb' (
id int,
name varchar(64),
status int,
createtime timestamp,
PRIMARY KEY (`id`)
)
-- 创建了三个普通索引
create index index_name on table('name')
create index index_status on table('status')
create index index_createtime on table('createtime')
-- 给定SQL语句,判断下面查询会用到几个索引
select * from tb where status = 1 and name = "zhangsan"
- 我们来聊聊LRU?叫你手写一个LRU算法谈谈你的思路?
- 用链表的方式实现,时间复杂度是O(N),有没有什么方式能够让它是O(1)的时间复杂度呢?
- OK,思路还可以,那你手写一个LRU算法吧?(双向链表 + Hash?)
- 反问环节:问了下组织架构,以及python和go在项目中的使用。然后问了下面试的表现,答:代码写的不算好吧,LRU写成这样我觉得是不太合适的。(心碎的声音,感觉到凉凉的气息...),结束后以为面试已经结束,后面在准备关页面的时候,面试官说等一下,还有同学和我聊?
HR面
花10来分钟做个简单的沟通
- 自我介绍
- 考研的时候为什么选择的是这个学校呢?
- 回顾一下,上大学到现在这段时间内,让自己最有挫败感的事情是什么呢?
- 有哪些方面需要在改进的么?
- 对于以后参加的工作,你主要会看重哪些方面呢?
- 同学这块,大家都有在投递字节这边的岗位么?
- 反问环节:关于面试结果,告知,这边只是做简单的了解,面试结果大约会在一周左右出来,到时候会有邮件或者电话通知。关于面试的结果,需要综合前面的几个面试官进行综合评测,才能决定是否录取。
总结+面试前的准备(供大家参考学习)
由于篇幅原因, 有需要完整文档的【点击“这里”】便可~
给大家个建议,面试官如果愿意和你聊组里业务,一定要把握机会好好聊,最好能提出让面试官眼前一亮的问题,直指业务核心。代码谁都会写,基础知识网上都能查到,但是对产品的理解和新的想法不是谁都有的
(1)第一步,面试前整理一个完整知识架构大纲
我将架构体系分为五大模块:并发编程、JVM性能调优、Spring开源框架源码解读、缓存数据库、分布式架构,微服务架构
(2)第二步,通过大纲对面试中的高频技术逐个攻克
1,并发编程(手写笔记:并发编程+并发编程原理+并发编程应用+并发编程_模式)
- 并发编程共享模型篇
- 并发编程_模式篇
- 并发编程_应用篇
- 并发编程_原理篇
并发编程共享模型篇
并发编程_模式篇
并发编程_应用篇
并发编程_原理篇
2,性能调优(Java性能调优实战:Java编程性能调优+JVM性能优化+Mysql调优笔记)
- JVM性能优化
JVM性能优化
- JVM性能监测及调优
JVM性能监测及调优
- Mysql调优笔记
3,Spring开源框架源码解读
[图片上传失败...(image-cbbe9f-1595839159821)]
4,缓存数据库
- Redis核心笔记
Redis核心笔记
- MongDB基础到进阶
MongoDB快速上手
MongoDB集群和安全
5,分布式架构
- Kafka源码解析与实战
6,微服务架构
- Spring Cloud Alibaba技术栈全解
- Spring Cloud微服务笔记
- k8s+Jenkins笔记
(3)第三步,刷面试题,面试字节跳动算法是必问的
团灭 LeetCode的算法刷题宝典
算法刷题小册
25大Java面试专题
字节跳动总体来说,面试体验还很不错的,尤其是在手撕代码题的时候,面试老哥会先叫你提供思路,如果你说的思路有问题的话,会帮你拨正,然后在进入coding阶段,但是怎奈何平时没怎么练习算法,leetcode做的少,面试两行泪。。这也算是提前批打响第一枪,期待后面精彩表现~
以上就是我在面试前整理搜集的面试资源和一个学习路线规划,希望能对大家有所帮助,有需要完整文档的【点击“这里”】便可~**