初次体验hiphop-php
昨天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 minimumversion字样,说明开发者可能就是在这个版本下开发的,我试了下最新版本的boost,编译到后来反而出错
- 如果yum上没有符合版本的lib库,可以手动编译,但是编译时建议就放在自己的home下,比如:
./configure--prefix=/home/user
- tbb Intel’s Thread Building Blocks这个包有些麻烦,记得按照wiki上说的步骤安装
测试hiphop-php
安装完成之后,时间也不是太多,所以我仅仅是简单的测试了一个php文件,代码如下:
PHP:
-
<?php
-
$i = 0;
-
for($j = 0; $j <1000000; $j++)
-
$i += $j;
-
-
echo $i, "\n";
-
?>
用hphp进行编译:
CODE:
-
hphp/hphptest.php –keep-tempdir=1–log=3
提示生成新的可执行文件
CODE:
-
/tmp/hphp_c9sbnG/program
做一下运行时间对比:
CODE:
-
$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,于是我重新编译并测试一遍这段相同的代码:
CODE:
-
$time /tmp/hphp_c9sbnG/program
-
499999500000
-
-
real 0m0.140s
-
user 0m0.076s
-
sys 0m0.006s
可以看到,经hiphop编译后的php,执行时间几乎快了一倍。
http://www.ooso.net/archives/541
分类: PHP