PHP语言, PHP扩展, Zend引擎相关的研究,技术,新闻分享 – 左手代码 右手诗

02 Dec 11 Yaf 2.1性能测试(Yaf 2.1 Benchmark)

Thanks to Ruilog agian for his work of second benchmark of Yaf 2.1.

Yaf 2.1 (github, manual) did a lot of work to improve performance and reduce memory usage, so let’s take a look at the result(Yaf 2.1重写了很多逻辑来提升性能, 并且降低内存使用率, 改进结果见测试对比):

First of all, I have to say, I am not saying the fastest is the best. every framework list blew is outstanding, and has particular situation to deploy. (首先, 我要申明, 不一定最快的就是最好的, 下面的每一个框架都是优秀的框架, 都有它们适用的场景)


Test Simple “Hello World” page output, Simple MVC logic(Router -> Controller -> Viewer), No Database Connections, No complex logic. Test scripts can be found here.

Hardware platform

  • CPU: Intel Core i5 750 (2.67GHz x4)
  • RAM: 4GB

Software Environment

  • Debian 6.0.3 x86_64 (2.6.32-39)
  • apache 2.2.16 (mpm-prefork,mod-php5)
  • php 5.3.8
  • php-apc 3.1.9 (Optimization for include/require)
  • Copy all projects to /dev/shm/* (Optimization for files read/write)

1. Apache Benchmark

Requests pre second (-c 100 -n 30000), the bigger is better

ab -c100 -n30000

Requests pre second (-c 200 -n 50000), the bigger is better

ab -c200 -n50000

2. System LoadAvg

System LoadAvg in 1 Minute when Apache Benchmark Complete, the smaller is better (-c 100 -n 30000)

System loadavg

3. Memory usage

How many memory usage in one “hello world” page. the smaller is better.

Memory usage

4. Response time

The time of page request to response.

Response time

5.Number of function calls (Facebook XHProf)

The number of functions calls in one “hello world” page.

Number of function calls

6. Number of included files

The number of files included or required in one “hello world” page. the fewer is better.

Number of included files

  * v20111201 @2011-12-01
    - release
  * v20111201-2 @2011-12-05
    - bugfix: Fix a stupid logic error in bench.php
    - bugfix: Symfony2, Change running mode from 'dev' to 'prod'


For more details, plz refer to:


Related Posts:

Tags: , , ,

48 Responses to “Yaf 2.1性能测试(Yaf 2.1 Benchmark)”

  1. Hotmail Login |

    It is a good and amazing article. Your information is very useful for me and for others. thank you so much.

  2. real madrid logo |

    We assume the delays are down to Ubi polish; The Stick Of Truth has the capacity to be an incredible game a mix of oldschool

  3. Gaming Mouse Review |

    I am new in php hope i will understand it

  4. alex |

    In file included from /home/alex/pirate/php/include/php/Zend/zend.h:841:0,
    from /home/alex/pirate/php/include/php/main/php.h:34,
    from /home/alex/pirate/nginx/html/yaflearned/yaf.c:21:
    /home/alex/pirate/php/include/php/Zend/zend_variables.h:51:15: note: expected ‘struct zval **’ but argument is of type ‘struct zval *’
    ZEND_API void _zval_ptr_dtor(zval **zval_ptr ZEND_FILE_LINE_DC);
    make: *** [yaf.lo] Error 1这是什么鬼,系统时centos 7

  5. Job search |

    Awesome info, thanks for sharing.

  6. Nolvadex Kaufen |

    Very nice. Thanks!

  7. MonacoEscort |

    Awesome info, thank you for shearing with us!

  8. Brandi |

    Thought it woldun’t to give it a shot. I was right.

  9. tiffany chains jewelry |

    And is particularly often the case most of us match in the everyday life.
    tiffany chains jewelry

  10. driving lessosn in warrington |

    Helpful info. Lucky me I found your website
    by accident, and I’m shocked why this twist of fate did not
    came about in advance! I bookmarked it.

  11. Sherryl |

    Wonderful blog you have here but I was curious if you knew of
    any discussion boards that cover the same topics talked about in this article?
    I’d really love to be a part of group where I can get suggestions from other
    knowledgeable individuals that share the same interest.
    If you have any recommendations, please let me know.
    web site (Sherryl)

  12. 導入 | PHP関数マニュアル |

    [...] Yaf のベンチマークが » Yaf Performance [...]

  13. domain |

    When I originally commented I clicked the “Notify me when new comments are added” checkbox and
    now each time a comment is added I get three
    e-mails with the same comment. Is there any way you can remove people from that service?

  14. Johnny |


  15. Anonymous |


  16. 奇言妙事-文学奇谈小小说阅读 » Yar – 并行的RPC框架(Concurrent RPC framework) |

    [...] Yaf 2.1性能测试(Yaf 2.1 Benchmark) Copyright © 2010 风雪之隅 版权所有, 转载务必注明. 该Feed只供个人使用, 禁止未注明的转载或商业应用. 非法应用的, 一切法律后果自负. 如有问题, 可发E-mail至my at Fingerprint: 73540ba0a1738d7d07d4b6038d5615e2) [...]

  17. phporigin |


  18. webcgo |


  19. 雪候鸟 |

    @pakey 看这里:

  20. pakey |


  21. Anonymous |

    /usr/bin/phpize ./configure –with-php-config=/usr/bin/php-config
    Configuring for:
    PHP Api Version: 20090626
    Zend Module Api No: 20090626
    Zend Extension Api No: 220090626

  22. michael |


  23. laruence |

    @cindy ming 暂时没有, 你可以使用不同的模板来实现, 或者使用自定义的视图引擎.

    不过, Yaf的视图引擎将会支持layout, 预计在2.2版本中

  24. cindy ming |




  25. laruence |

    @keda Yaf_Application的第二个参数:

  26. keda |

    不知道这个算不算是个问题,用于决定YAF application config 的 yaf.environ php value似乎只能通过添加到php 本身的ini文件里面来改变,而不能通过ini_set 或者是 修改local htaccess 文件来改变。
    如果在一台机器上需要有几个YAF项目以及不同的env值的话,单个值似乎是个问题。。并且改变需要root access,更是问题。。

  27. |

    Hi, laruence
    Configuring for:
    PHP Api Version: 20090626
    Zend Module Api No: 20090626
    Zend Extension Api No: 220090626 warning: prefer named diversions warning: prefer named diversions


  28. laruence |

    @keda 非常感谢你们的反馈, 问题已经修复. 请使用2.1.5beta

  29. keda |

    gcc (Debian 4.4.5-8) 4.4.5 64bit系统。
    跟Adam Lu的error一样。。
    yaf.c:265: warning: initialization makes integer from pointer without a cast
    yaf.c:266: warning: initialization makes integer from pointer without a cast
    yaf.c:266: error: initializer element is not computable at load time
    yaf.c:266: error: (near initialization for ‘yaf_module_entry.module_number’)

  30. laruence | 你可以打开php.ini中的display_startup_error看看有什么错误

  31. |

    mac os 中的php版本试5.3.8


  32. 雪候鸟 | 请问你的PHP的版本是?

  33. |

    Hi, Laruence.

    我在mac os x 10.7.2 上无法安装yaf-2.1.4。

    运行phpzie的时候提示: warning: prefer named diversions warning: prefer named diversions

    yaf.c:265: warning: initialization makes integer from pointer without a cast
    yaf.c:266: warning: initialization makes integer from pointer without a cast
    yaf.c:266: error: initializer element is not computable at load time
    yaf.c:266: error: (near initialization for ‘yaf_module_entry.module_number’)
    make: *** [yaf.lo] Error 1

  34. Anonymous |

    @雪候鸟 非常感谢!我已经用ReflectionClass把Yaf扩展里的类都抽象出来了,写的很简单,不过可以用^ ^ 这下在zend里开发就方便多了,有需要的同学可以到下面的链接下载

  35. dvaknheo |


    再后来想想, 不行, 那样就就搞得系统零碎。

  36. 雪候鸟 |

    @thinklong 我这边没有, 不过你可以借助reflectclass自己生成一个 :)

  37. Thinklong |


  38. Eryx |

    @Wellming Symfony2 的配置确实存在问题,切换到 prod模式后并发大概是 400+, 介于 ZF 1.11 和 2.0 之间

  39. venkman |

    如果虚拟主机上的php不支持或没有安装这个扩展, 那么推广还是有一定的

  40. Wellming |

    @Eryx 你看下app.php跟app_dev.php文件,

    $kernel = new AppKernel(‘prod’, false);
    $kernel = new AppKernel(‘dev’, true);


  41. kernel |

    symfony2这么差啊,ps: yii的表现还不错啊,于是继续用yii

  42. xiatian |


    “E:\webServer\php\ext\php_yaf.dll”的激活上下文生成失败。 找不到从属程序集 Microsoft.VC90.DebugCRT,processorArchitecture=”x86″,publicKeyToken=”1fc8b3b9a1e18e3b”,type=”win32″,version=”9.0.21022.8″。 请使用 sxstrace.exe 进行详细诊断。

  43. helloyou |





  44. Eryx |

    解释下 app_dev.php 问题:

    刚开始的时候,常识用 app.php 引导,但失败(500 error); 而同时 app_dev.php 正常,为了消除 debug 对性能的影响,在 config_dev.yml 中做了如下修改 ([web_profiler] toolbar: false; intercept_redirects: false). 使其可以输出一个干净的 “hello world”.
    我想,虽然名称上叫做 “dev”, 但实际配置应该和 “app.php” 等同.

    Symfony 是一个历史悠久、成熟的商业框架,但我却是第一次使用,如果你有更优化的配置,期待您提交补丁 :)

  45. KnightE |


  46. Wellming |



  47. 东爷 |

  48. Yaf的性能对比测试 | 风雪之隅 |

    [...] 后记(2011-12-02补充), Yaf 2.1做一些性能优化的升级, 基于Yaf 2.1的性能测试报告可以参见: Yaf 2.1性能测试(Yaf 2.1 Benchmark) [...]

Leave a Reply