Sicheng’s blog

The Sicheng's blog

记录我曾经面试 Facebook(Meta) 的经历

2020 年初的时候,我的邮箱里面收到一个封 Facebook 的招聘邮件。能被大公司看上,我还是挺高兴的。于是热情洋溢的回了邮件,说我很感兴趣啊,Facebook 一直是我的 dream company 等等。 面试 于是他们很快的给我安排了第一轮面试,就是两道非常普通的 LeetCode 算法题,我那段时间一直在刷题,所以很快的写出来了。所以他们就安排 4 月份去伦敦 onsite 面试了。 我当时签证和机票都搞好了,结果新冠在欧洲爆发,onsite 面试改成线上。这是我非常遗憾的事情,因为相当于免费旅游没有了,我定的酒店就在大英博物馆走路能到的地方。 线上 onsite 是一天面试完的,我记得好像是 4 轮,题目完全不记得了,基本上都是 LeetCode 的原题,就是考的一个手快。系统设计轮要我设计一个线上卖演唱会门票的系统,非常像 Educative 上的一个系统设计课程讲的  Design Ticketmaster,正好我前几天看过。我觉得这个题最关键的就是考虑并发的时候,多个客户端如果想买一个座位的票会怎么样。我就说这个时候应该用锁,并且解释了数据库乐观锁和悲观锁的区别和适用场景。 Offer 面试很顺利,我的 recruiter 一个星期之内就和我沟通,说面试通过了,要和我谈 offer 了!当时接到电话还是挺兴奋的,毕竟是顶级互联网公司。他们给了我一个 E4 的 offer,大致一年在 12 万英镑左右,还有将近两万英镑的搬家费。Offer 一年之内有效。 我的决定 兴奋过后,我也在考虑到底要不要搬去伦敦。那段时间我聊了很多人,包括已经在 Facebook 伦敦工作的朋友。 首先关于职级,E4 感觉不上不下的,Facebook 有一个非常有名的 Up or Go 的政策。Facebook 希望工程师在 一定时间内升级到 E5 […]

Continue Reading

一些 System Design 面试的建议

最近有些朋友在找工作,不少人倒在 System Design 这一轮上。我作为面试者和面试官都参加过 System Design 的面试活动,就写篇博客聊一下我觉得 SD 面试有用的 tips。 首先明确两个事实: 面试的时候,人或多或少都有压力。人在压力下就会忘记东西,或者动作变形。 面试官多数情况比你考虑得点要多,不一定是因为他们水平比你高,而是因为他们的问你的问题可能已经问过其他人无数遍了。可能他挖了很多”坑“等着你跳。 针对第一点,我的应对方法是形成自己的一个 固定的 routine。久而久之形成习惯了,就变成下意识的动作了。这样我就尽可能的不会错过重要的点。我一般都是按照这种次序做 SD 的面试的。 理清楚需求 SD 面试常见的题目就是一开始用一两句简单的话说出一个需求,然后让你设计一个系统去满足。为了考察面试者理清楚需求的能力,面试官都会讲得非常简单。这个时候,需要你通过不断提问的方式从面试官嘴里”挖“出他的真实意图。如果面试者碰到过网上同样的题目,然后直接就略过了这一步,那么恭喜你,这一轮面试你很难通过。 我一般从功能性需求出发,尝试去了解面试官到底想要什么,以及整个业务流程是怎么样的。我记得我参加一个一次面试,面试官要我们设计一个网上商城卖书。我问了很多问题,其实有一个问题是,我说这些书是哪里来的,是先买好了库存还是怎么样?这个时候面试官邪魅一笑,说库存是每天晚上从出版社通过上传 Excel 的方式录入到系统中的。很显然,如果我不问,他肯定不会主动告诉我的。 除了功能性需求以为,我也会尝试着问问一些非功能性需求,比如整个系统是对外的还是内部系统,需要鉴权或者登陆什么的吗。 聊一下系统容量 理清楚需求以后,最好问一下系统预估的容量是多少,比如有多少用户,多少商品,等等等。这个一般涉及到存储的选择 定义系统接口和业务 entity 一个系统总需要和外部交互,就需要提供接口。这里的接口可以一般是一些 HTTP 的接口,也有可能是消息队列的 schema。我在这里说的是接口而不是具体实现。比如如果设计一个用户中心,我就会说我会提供一个接口,客户端可以 create a new user with these properties。到这一步,我不会具体说,我要实现用 Restful 或者 RPC 的方式实现一个创建用户。我就碰到过面试者,在设计接口的时候,默认选择 Restful API,然后花很多时间去讲一些细节,结果没有时间和面试官讨论其他的东西。同样,了解完业务以后,系统中一定会有一些实体(entity)的。我一般根据我的理解,把业务实体给写下来,每个实体有哪些哪些字段。和接口一样,我不会说这些实体我需要用什么数据库保存。我只会和面试官说,我的系统里面有这些实体,我会把他们存在某个存储中。 如果这个时候,有时候有一些面试官会想和我聊一下细节,比如用什么数据库等等。我都会说,让我们先把高层的设计做完在去讨论某些细节。这样面试的节奏一直是自己熟悉的节奏,也显得我比较有信心。 画一个高层的架构图 到了这一步,我基本上脑子里面有个大致的架构图,这个时候我会用一个画图软件把这个架构图给画出来,我一边用Excalidraw这个网站。注意,在架构里面,我也没有指明任何任何具体的技术栈,数据库就是数据库,而不是 MySQL 或者 Redis 什么的。把这个高层的架构图给画出来以后,我会把一个业务流程的数据流给面试官讲解一下。比如如果创建一个用户,首先由 client 发起一个请求,服务随后写入数据库,然后发一条消息等等。 […]

Continue Reading

2022 07 冰岛行

微信上有 1000 万人定位在冰岛,而冰岛的实际居民才 37 万,作为对比,北京天通苑有 60 万人居住。据说冰岛是世界上最像外星球的地方。 2022 年 7 月,我请了一周半的年假,准备来一次冰岛 7 天环岛游。这篇文章是我对这次旅行的记录。 出发 我们是从柏林勃兰登堡机场直飞冰岛的,这是我第一次去柏林的“新”机场。所谓的“新”是指的是机场 2020 年才启用,打了引号是因为这个机场一直修建了 14 年。这个机场也成为了德国的一个国家笑话。我曾经和我的德国同事聊天,我问为什么柏林的柏林泰戈尔机场没有通地铁?明明有一条地铁线是往那个方向去的。我同事说当时修地铁的时候,柏林新机场已经在建了,规划的人觉得等地铁修建好之前新机场就会启用了,所以没有必要把地铁修到老机场。谁知道,这一修就是 14 年。这 14 年里面,柏林人去泰戈尔机场都需要做公交车。 新机场看上去很高端大气上档次,但是我觉得和很多机场一样,过了安检到登机口需要走非常长的一段距离。感觉机场的设计者就是为了让人多在免税店消费。我不禁怀念泰戈尔机场的简洁实用。 冰岛虽然叫做冰岛,但是因为受海洋暖流的影响,其实并不冷。同样的,因为海洋寒流和暖流交汇,气候比较多变。这是冰岛航空飞机上的垃圾袋的背面,介绍了冰岛的气候。   路线 冰岛一个是岛国,我们的计划主要沿着冰岛的 1 号公路做一次环岛旅行。整个行程大致 2000 公里。 黄金圈 和所有人一样,冰岛的旅行一般都是从“黄金圈”开始的。黄金圈指的是冰岛西南部的三大景点:辛格维利尔国家公园(Þingvellir National Park)、盖歇尔间歇泉区(Geysir)、黄金瀑布(Gullfoss)。这三个景点彼此距离很近,其壮丽的景观为冰岛所独有,因此而闻名世界。 辛格维利尔国家公园位于北美板块和欧亚板块分离所产生的巨大裂谷边缘,非常壮丽。但是其实我也看不出出来,唯一让我感兴趣的就是这里是权游的拍摄地,第四季的鹰巢城的取景地就是在这里。 从国家公园出来接着开车去了间歇泉,泉如其名,这泉每隔 5 – 10 分钟喷发一次。所以能看到游客拿着手机捕捉泉水喷发的一瞬间。 黄金圈的最后一站是黄金瀑布,黄金瀑布(Gullfoss)又译为居德瀑布、古佛斯瀑布,发源自冰岛西南部的Hvítá白河,是冰岛最壮丽、最著名的瀑布之一。 Hvítá白河发源自朗格冰川(Langjökull);河流跌落32米,历经两级阶梯,最终汇入峡谷,塑造了黄金瀑布这座壮观的双层瀑布。黄金瀑布与辛格维利尔国家公园、盖歇尔间歇泉地热区共同组成了冰岛最受欢迎的旅行景区——黄金圈。 塞里雅兰瀑布 塞里雅兰瀑布(Seljalandsfoss)位于冰岛南岸,坐落于冰岛一号环岛公路旁,高约60米,造型似“水帘洞”,可穿行至瀑布后方。便利的交通与旖旎的风光使其成为了冰岛最著名、最多游客到访的瀑布之一。 景点本身不收钱,但是停车票需要 700 冰岛克朗,折合人民币 35 块钱的样子。在我排队的时候,有个姐们跟我打招呼,问我会不会说英文。我说会,她说她们要走了,问要不要买她的停车票,500 克朗卖给我。反正票能停一天。我心想说,你这也太会精打细算了吧,然后马上就同意了。 看完瀑布,我发现停车场上还有不少骑摩托车环岛的。有个摩托车竟然是德国的牌照,也不知道这些摩托车发烧友是怎么把摩托车车给运到冰岛来的。 取车的时候,我发现有一对美国来的夫妇排队准备买票。我连忙 Hello,Hello […]

Continue Reading