最近收到邀请,回答这个问题。
其实Facebook已经是10多年的公司了,技术方面以现在的视角看,略显陈旧,不建议现在的公司去刻意模仿他的技术栈(其开发工具和新的开源项目,还有里面的软件开发思想倒是很好的)。
我来说我一个我自己的版本:
主要的编程语言是php,里面有大量的fb后来开发的扩展库。也有转c和编译的hphp,再到后来的高性能vm。
现在fb开始越来越多地使用前端渲染和处理,大量使用js和后来新推出的react。思路就是将前后端尽量解除耦合,之间只交换数据(调rest api来取数据和扭转数据的状态)。
php的背后则是大量的java和c++的代码,来处理后端一些深层次的逻辑,比如 news feed ranking,antispam,推荐算法,ads ranking,messaging backend等等。他们游离在PHP的背后,是一个一个独立的service,通过thrift来和PHP以及他们互相间通信。
在移动端,刚开始是原生(那时只有原生)。2011年底开始浪,想用html5一统江湖,但是吃了巨大的苦果,于是后来又全部换回native。ios的用objc,android的用java,一部分不常用的功能保持在html页面。
最后自己的思考就是:
技术和创业公司是一轮接一轮向前发展的,长江后浪推前浪。现在的Facebook团队要是刚开始创业的话,按照peter thiel的说法,他们不会再做social network。那么我的补充就是,他们也不会使用当时的技术栈,而是用当前更为轻便的方案,比如: python+django,或者ruby on rails,或者是node.js etc,而后端服务亦或是驾于amazon web service之上,甚至是Google app engine或者parse上。