首页 > PHP > 初次体验hiphop-php

初次体验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:

  1. <?php
  2. $i = 0;
  3. for($j = 0; $j <1000000; $j++)
  4.        $i += $j;
  5.  
  6. echo $i, "\n";
  7. ?>

用hphp进行编译:


CODE:

  1. hphp/hphptest.php –keep-tempdir=1–log=3

提示生成新的可执行文件


CODE:

  1. /tmp/hphp_c9sbnG/program

做一下运行时间对比:


CODE:

  1. $time php test.php
  2. 499999500000
  3.  
  4. real   0m0.307s
  5. user   0m0.299s
  6. sys    0m0.007s
  7.  
  8. $time /tmp/hphp_c9sbnG/program
  9. 499999500000
  10.  
  11. real   0m0.259s
  12. user   0m0.194s
  13. sys    0m0.008s

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

Update

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


CODE:

  1. $time /tmp/hphp_c9sbnG/program
  2. 499999500000
  3.  
  4. real   0m0.140s
  5. user   0m0.076s
  6. sys    0m0.006s

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

http://www.ooso.net/archives/541

分类: PHP 标签:
  1. 本文目前尚无任何评论.
  1. 本文目前尚无任何 trackbacks 和 pingbacks.

=3加8(必填)请输入两数相加的结果。