人气 5885

Facebook的CTO,以及一流的企业文化是什么样的? [复制链接]

精益人 2022-4-22 13:10:45
本帖最后由 精益人 于 2022-4-22 13:12 编辑

创业公司应该如何创造自己的工程师文化?以及Facebook的看家产品NewsFeed背后的原理。


Facebook.jpeg


创业者常常会说:“请帮我们找个CTO吧。”确实,资深工程师不少,但合格的CTO却不多。作为“C”字头的技术人员,CTO所关注的绝不仅仅是工程质量这么简单。内部运营的管理、HR事务、整体架构都需要用到这位资深码农。而就算从硅谷挖来一位技术大牛,应该如何与之磨合,也是困扰国内创业团队的一个问题。
那么,Facebook在打造企业文化的时候都做了什么?创业公司可以从中学到什么?
Facebook的CTO都在做些什么?
覃超:峰瑞资本技术合伙人,前Facebook工程师。
我在2010-2014年在Facebook工作,主要负责前端移动开发,从FacebookPhone到iOS/AndroidFacebookApp和Messager等做过很多功能。同时我之前做过PHP后端的东西。
Facebook第一特点就是重视技术兼设计。不像苹果纯设计而谷歌纯技术,Facebook是各占50%。公司整体装饰有意外多的艺术元素,而新的总部大楼更是由巨擘FrankGehry设计的。


公司内部的彩虹样式装修,是美国高院宣布同性恋合法时加上的,也体现公司对于不同事物的包容和尊重。产品的活力和企业文化包容有很大的关系,所以我建议创业公司不妨都包容开放一点,比如放一个无人机或者OculusVR的眼镜就很棒。


公司里还有很多Poster,其实我觉得这Branding和企业的“政治教育”内容。这些海报并不是专门一个人做,公司每个人都做,且公司有一个房间是专门造这些东西的材料,只要你把你的设计交给他们,最后海报就会制作出来。
Facebook另一个特点就是开放,没有严格的权限控制,例如iOS可以看到后端代码,PHP可以看安卓的代码。任何员工只要在公司的内网里,就可以随时打开数据展示的页面,然后看到公司的MAU(MonthlyActiveUser-月活),DAU(DailyActiveUsers-日活)以及其他按照地区和功能切分的细节数据。这样可以节省工作的管理开支,每个人也不会觉得束手束脚。
另外我们的工作空间就是网吧式的结构。这样有两个特点,好交流也闹哄哄。最重要是有PeerPressure,比如你迟到或者打游戏,都会被别人看到。比起其他很多美国的好处是,在Facebook工作刷NewsFeed或者微博和知乎是不会被限制的。


公司另一特点是默认给予员工最大程度的信任(按照老美的话说:trustbydefault),这也是美国文化的特点之一。一进公司就默认对你信任和尊重。它的相对应面是绝对强的执法能力,如果你泄露公司机密,则立马把你开除。历史上出现过几次Zuck在QA的会议上说的公司机密被泄露的事件,那些泄密者最后基本都被开除。


一个公司最重要的是气氛的和谐。不仅是程序猿之间,还有和设计师、PM,他们也会参加一些讨论,且我们一定要坐在一起,这样类似UI上细节的问题,比如颜色、像素对齐等,都可以当面沟通。即使Facebook的远程会议系统和线上沟通工具都已经很健全了,但公司还是鼓励坐在一起工作。
Facebook项目的人员配比:一个项目一般是两三个设计师、5-10个工程师2-3个产品经理。每个月一波推进(Scrum里强调的sprint),包括2-3个功能,按每个功能分一小组来做,但设计师可能会同时做多个设计。Facebook的流程其实比较传统,但又夹杂很多敏捷开发的元素:一般是设计师先进行设计,然后工程师来开发,但整个过程中双方又经常有交互。整个产品研发过程中,所有人都互相尊重、互相合作,从一开始设计师、工程师、PM都会在一起讨论,做出来之后还会坐在一起讨论,会马上给一些反馈,然后马上修改好。
工程师写代码的时候也会跟设计师一起交流,交流用的是IRC外加FacebookChat。但这些我觉得比较过时,比起微信来说,它们算难用的,甚至还没QQ好用。任务管理方面,Facebook有自己的InhouseTask系统,可惜没有开源。类似的工具,现在Trello、Tower、Teambition或者Jira就很好用,可以用来做产品上的规划,开发进度管理和bugtracking。
最后我们的IC、release、monitoring这些全部都是内部工具,开发花了不少人力,对于创业公司不是特别适用。对持续集成来说,我觉得最经典的是Jenkins,但是它的问题就是功能繁复、界面像80年代的软件。如果你们用Github的话,我也推荐TravisCI和Drone。


在硅谷公司里,在开发流程上我觉得最重要的就是:CodeReview。Facebook、Google、Uber到现在的Airbnb,无一不是强制要求CodeReview。Codereview过程中,不仅是可以互相检查对方的代码,还可以自动跑lint和unittest,对于代码质量的提高和去除没必要的bug非常有帮助。
这里重点推荐一下Facebook的Phabricator。
它是个开源的代码审核和任务管理工具;它的其他功能也极其丰富;还可以搭在私有的服务器上,使其代码和数据不会被盗用。另外我们基金已经把它进行了汉化,变成中文的一个定制版本,并且扩展到其他功能上。比如对BP的审核工作:我们自建了机器人来监控我们BP邮箱的内容,然后对于每一个进来的BP,自动在系统中建立DealReviewTask;然后我们的BP审核人员和投资经理们跟进。


最后一点Facebook让我觉得印象深刻的,是它对于工程师技术能力的高要求和提供的一整套培训。另外就是在硅谷公司工作,要学会有效地描述表达一个观点,逼自己去学和反复复习。我觉得反复的一个过程很重要。反复的过程中,看似在做重复的事情,但是每次我都会意外地迸发出新的灵感。最后对于设计这一块,我们有一个特别强大的设计工具Origami,可以很方便做交互设计,并且支持直接生成特效的代码。


以下来自徐万鸿:神州专车CTO,前Facebook工程师。
Facebook的NewsFeed(新闻流)是怎么做的?新闻流(NewsFeed)是Facebook最重要的产品,有10亿用户,平均每个用户每天会收到他关注的朋友/主页所推送的2000个以上stories。
实时发布,不漏掉重要的story
从发出story到其他人接受story的时间在1秒之内,其中排序所花的时间在200毫秒之内。Dataloss要小于1E-6,实现这一点的关键在于系统架构。
把最好的内容放在前面
用户更倾向于与页面前面的内容互动,所以把更好的内容放在前面会带来用户在Facebook上更大的参与度。实现这一点的关键在于Ranking部分。
系统架构部分
Pushmodel和Pullmodel这两种模型都是可行的。
Pushmodel写入多次,读取一次。如果有1W粉丝,发布一条消息,会存储在每个粉丝那里,存储1W次。这个模型速度比较快,但是需要存储比较多。Pullmodel写入一次,读取多次。发布的都写在一个库里,然后每个用户都来读这个数据。
Facebook内部更倾向于Pullmodel,因为Pushmodel需要太多的存储空间。
Ranking部分
如何确定哪些是更好的stories?我们需要给每一个story打分。我们赋予不同类型的行为不同的权重。比如click,like,comment。这几种行为中,comment需要更多的代价。click的代价很小,而comment意味着用付出更多的时间来互动,所以我们会给comment更高的权值。
对于每一个story,我们需要预测这个story被推送给用户后点击、点赞、评论的概率。这里会用到机器学习(machinelearning)的算法。先要实时地生成features,然后要利用数据来trainmodels,最后publishmodels,得到每个用户对每个story的每种行为的概率。
关于个性化的部分,采用的是通用的模型和个性化的信息。如果能针对每个用户做不同的model,效果会更好。但是用户数目太多,这部分的工作量过大。
同时这也是一个实时反馈的系统。用户对每个story的行为会实时反馈到这个模型里面,重新训练模型,让效果越来越好。

您需要登录后才可以回帖 登录 | 立即注册

QQ|手机版|精益人 ( 沪ICP备19004111号-1 )|网站地图

GMT+8, 2025-1-2 23:22 , Processed in 0.239566 second(s), 25 queries .

Powered by Lean.ren X3.5 Licensed  © 2001-2030 LEAN.REN