HipHop先把PHP代码转换成C++代码,让后使用C++编译器如GCC编译成目标机器码.
HipHop用来提高Facebook服务器的使用效率. 目前,超过90%的Facebook网站流量经由HipHop编译的PHP代码处理.多线程WEB服务器使用更少的内存, 因为它使用单个内存池来处理所有并发请求. 这和多进程WEB服务器(如Apache的Pre-Fork模式)有显著的不同.
目前绝大多数PHP WEB服务器都是多进程模式,在这种模式下,每个请求会被不同的系统进程处理。每个进程拥有自己的内存池。
多进程模式的主要问题是,如果一个进程占用了大量内存,在该进程退出之前,这些内存无法返回到系统中,即使该进程处理的后续请求并不需要这么多的内存,而多余的内存空间不能被利用来处理其他的并发请求。
比如,如果你有一个1GB内存的WEB服务器,每个PHP请求占用10MB,那么理论上能够同时处理的并发请求数为100。
如果同时运行的应用程序使用的内存超出了可用的物理内存,操作系统会启用虚拟内存,把物理内存中的部分内存块置换到磁盘的虚拟内存区,这样系统性能将迅速下降。
HipHop一个新的方面是Facebook工程师把PHP扩展转换成了线程安全的代码。
这里顺便提一下还有一些非机器码PHP编译器,比如编译成Java字节码的Quercus 和 Project Zero, 或者编译成.NET assemblies 的Phalanger。