初次体验hiphop-php

Ooso 发布于2010-02-21 10:19 | 288次阅读 | 字体: 打印预览


昨天facebook在github上发布了hiphop-php的源代码。之前听说这玩意能把php代码翻译成c++代码,然后带来巨大的性能提升,所以第一时间编译了一份hiphop-php。

我的机器环境是 Centos 5.3 x86_64 8G内存 Intel(R) Xeon(R) CPU E5420 @ 2.50GHz 安装注意事项

编译的时候碰到的问题很多,但是基本上都是按照wiki上的步骤进行的。我觉得比较重要的几点:

wiki上的Required Packages包包列表都要检查一遍,比如版本号,是否安装过,像binutils-dev这种就很容易忽略 版本符合的话,直接用yum安装这些包就可以了 wiki上有类似Boost 1.37 is the minimum version字样,说明开发者可能就是在这个版本下开发的,我试了下最新版本的boost,编译到后来反而出错 如果yum上没有符合版本的lib库,可以手动编译,但是编译时建议就放在自己的home下,比如:

./configure --prefix=/home/user tbb Intel’s Thread Building Blocks这个包有些麻烦,记得按照wiki上说的步骤安装 测试hiphop-php

安装完成之后,时间也不是太多,所以我仅仅是简单的测试了一个php文件,代码如下:

用hphp进行编译:

hphp/hphp test.php --keep-tempdir=1 --log=3

提示生成新的可执行文件

/tmp/hphp_c9sbnG/program

做一下运行时间对比:

$ time php test.php 499999500000 real 0m0.307s user 0m0.299s sys 0m0.007s $ time /tmp/hphp_c9sbnG/program 499999500000 real 0m0.259s user 0m0.194s sys 0m0.008s

没看出来编译成c++代码之后有太大的性能提升,估计是俺的使用手法问题?在邮件组里观察几天再说。

Update

facebook将优化之后的编译参数提交到了github,于是我重新编译并测试一遍这段相同的代码:

$ time /tmp/hphp_c9sbnG/program 499999500000 real 0m0.140s user 0m0.076s sys 0m0.006s

可以看到,经hiphop编译后的php,执行时间几乎快了一倍。


本文出处 : http://www.ooso.net/archives/541 end

上一篇:快速安装hiphop-php的捷径

下一篇:git的代码review工具