两年前端头条面试记

今年还未曾面试过,如果不是头条的某个 HR 顺手把我的简历从简历库中捞起来的话。头条是大小周,这就意味着我可以周末去面试,不占用工作时间也不用请假,对于这点我还是很满意的。

面试约到了周日早上十点,但事后我有点后悔,周日面试官很可能会晚点。面试一直持续到下午三点左右结束。

头条的效率确实很高,周日面试结束后,第二天 hr 就通知了面试通过。

另外,我把本次面试也记录在我的每日一问: shfshanyue/Daily-Question 中,欢迎讨论与 star

背景

到今年年底,我已经有了将近两年半的经验。而这两年来的时间可以一分为二,第一段时间我在整前端,用的 react,第二段时间我在整后端,用的 node,我们用 node 直接操作数据库,而非作为中间层。而由于人事的过多调整,我在这时也做过一小段时间的 leader。做后端改BUG总是要调线上数据库的,再加上我对运维的兴趣,因此我拥有了线上数据库以及k8s集群的权限,并直接维护我们项目组业务代码的 k8s resource。(当然,后来改到 helm 维护)

由于 node 与前端千丝万缕的联系,以及我在头条的简历没有更新,因此这次接收到的还是前端面试邀请,不会也有一些 node 的知识。

面试

面试整个过程持续了四个多小时,聊的东西还是很多

  • 简单的自我介绍与项目经验

  • 一道算法题

  • 一道 setTimeout/Promise 输出顺序问题的题

  • 什么是事件循环

  • react 中的 key 用来做什么

  • 什么是 virtual DOM

    • 就是虚拟的DOM,提高渲染的性能,数据与UI分离,并且有利于服务器渲染

  • webpack 的原理是什么,loader 和 plugin 的作用是什么

  • ssr 的原理是什么,解决了什么问题

    • renderToString,hydrate;首屏时间与SEO

  • ssr 会有那些坑

    • cpu/memory 可能爆了,出现异常不好定位调试,带权限接口与非权限接口有可能需要剥离(为了缓存),TTFB慢了(如果不加缓存,以前可能是骨架屏,现在直接白屏),由于需要起http服务工程上也复杂了很多

  • 你如何看待前端和后端

    • 吧啦吧啦吧啦...

  • 有没有了解过 shell

    • 这个肯定得了解过

  • 如何替换一个文件中的内容

    • sed;那还有没有其它命令;cut

  • 有没有用过 awk

    • 只能说有了,不过没具体问用法

  • 对一个文件如何只查看特定行的内容

    • 用 head 应该可以吧...(不太确认)

  • 你们的 node 的服务端应用如何部署

    • 然后讲了讲我们node部署的历史,从以前的 pm2 到 docker,到 openshift 再到 k8s

  • docker 部署有什么好处

    • 各种好处,吧啦吧啦吧啦

  • docker 的底层原理是什么

    • namespace 和 cgroups,一个隔离环境,一个控制资源配额。多亏我看 docker 的时候多看了一遍简介...

  • 那隔离环境主要隔离什么环境

    • 根据我对 docker 的映像说了网络,memory,进程,volume。回去之后看了看才知道是在问 linux namespcaces 有哪些..

  • 有没有了解过 ufs

    • 没有...回去之后发现这就是 docker 的分层存储,虽然一直知道它是分层存储,但不知道叫 ufs

  • 部署 node 时如何充分利用服务器的多核

    • 比如用node 的 cluster,用 k8s 也能部分利用多核性能

  • 如果你要读取一个特别大的文件应该如何做

    • 那时候还不知道 stream...于是就说了不停地 seek offset

  • 你们有没有对服务端的异常进行监控

    • 比如用 sentry 监控异常,elk 打日志,prometheus 监控性能并用 alertmanager 报警,再写一个webhook到钉钉

  • 那你们在线上出现问题时如何在应用层面监控 cpu 和 memory 的信息

    • 虽然线上出现过问题,,但这个确实不清楚。cpuheapdump

  • 如何查看一个 node 的服务端应用的内存和CPU

    • ps / pidstat

  • 当服务端的内存发生了 OOM 问题如何排查

    • 比如看 promethues,查看监控的突然高峰,看日志那段时候发生了什么,看有没有提交代码

  • 数据库中什么是 left join 和 right join 有什么区别

  • 数据库索引中为什么要用 Btree

    • 减少与磁盘的IO次数

  • 什么是聚簇索引

    • 这是啥...

  • redis 如何做持久化

    • 我还在想持久化好像不太重要,有一次我们线上的 redis 刷了一遍,也仅仅是用户掉线了而已...持久化有两种方案,具体忘了叫啥了。一种是隔一段时间备份数据,另一种是备份命令,按照命令备份数据。回来一查是 RDB 和 AOF

  • 如何实现一个分布式锁

    • set key value EX 60 NX

  • 有没有用过 LUA

    • 并没有,但不能说没有啊。于是说我看过一个关于 rate limit 的库的源码,里边的 redis 就是用的 lua 脚本

  • 当一个地址从输入到展示在浏览器中有哪些步骤

    • 吧啦吧啦吧啦

  • 递归解析的过程是什么样的,什么叫递归 DNS 和权威 DNS

    • (问这么偏...)

  • TCP 为什么是可靠的

    • 因为它有 ACK

  • 那 tpc 和 udp 相比的话,udp 有什么好处,虽然不可靠,但是为什么还有很多基于 udp 的协议

    • 因为 upd 报文小,udp 头部8个字节,tcp 头部20个字节,而且有些协议也不需要太可靠。面试官看我把报文 header 大小答出来了,然后看了下简历发现我是学网络工程的。其实我网络工程学的也忘的差不多了 (刚开始都能记住TCP的六个标志位)

  • 为什么要换工作

  • 以前通过了面试怎么没有来

    • 因为没 hc 了......

  • 你有什么要问的吗

总结

经过本次面试后,愈发感觉自己一些底层知识的薄弱。另外也感叹于面试官技术面的广度与深度,深知拓展技术栈也是相当重要。

最后

  • 欢迎加我微信(winty230),拉你进技术群,长期交流学习...

  • 欢迎关注「前端Q」,认真学前端,做个专业的技术人...

点个在看分享这篇文章吧

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值