两年前端头条面试记

今年还未曾面试过,如果不是头条的某个 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 了......
  • 你有什么要问的吗

总结

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

posted @ 2019-12-04 16:32  山月水风  阅读(668)  评论(0编辑  收藏  举报