`
cppmule
  • 浏览: 436798 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类

初次体验hiphop-php,转化php为C++代码。

    博客分类:
  • php
 
阅读更多

初次体验hiphop-php,转化php为C++代码。

 

 

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

我的机器环境是Centos 5.3 x86_648G内存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/usertbb Intel’s Thread Building Blocks这个包有些麻烦,记得按照wiki上说的步骤安装测试hiphop-php

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

<?php
$i =0;
for($j =0; $j <1000000; $j++)
        $i += $j;

echo $i,"n";
?>

用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,执行时间几乎快了一倍。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics