PHP性能监测的工具介绍XHProf.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PHP性能监测的工具介绍XHProf

XHProf 这个软件本是Facebook内部的一个应用工具,2009年3月份开源,为PHP的性能监测提供了很好的工具。官方的介绍中提到: XHProf is a hierarchical profiler for PHP. It reports function-level call counts and inclusive and exclusive metrics such as wall (elapsed) time, CPU time and memory usage. XHProfs light-weight nature and aggregation capabilities make it well suited for collecting function-level performance statistics from production environments. 可以先来看看 XHProf 提供的图形界面的截图 XHProf的一些特性: 1、Flat Profile. 提供函数级的汇总信息,比如调用次数、执行时间、内存使用、CPU占用等。 2、Hierarchical Profile。 对每个程序,进行了父级调用和子级调用的分解。 3、Diff Reports(差异报告)。有很多种情况,我们希望能够对比,比如新版本比旧版本提升了多少速度,两个版本的差距究竟在哪里。Diff Report 就是这样的工具,接收两个输入,并且分别给出各自的 Flat Profile 和 Hierarchical Profile 报告。 4、Callgraph View(调用视图)。性能监测的数据可以绘制成调用视图,方便我们查看。 5、Memory Profile(内存监控)。这个特性帮助我们了解PHP如何分配和释放内存。值得注意的是,XHProf并不是严格的监测内存的分配和释放动作,而是计算每个函数进入和退出时的内存状况,这是一个相对简单的实现方式,但是基本上也能够满足我们日常的监控需求。 6、如何处理外部文件。XHProf将 include,require,include_once,require_once进来的文件视作是一个 function。 XHProf目前只支持一个级别的函数追踪,但是貌似也没有特别大的影响。 XHProf的安装配置 xhprof的安装配置很简单,我们首先在 PECL 的网站上下载 源码包 然后执行安装过程 % cd xhprof_source_directory/extension/ % phpize % ./configure --with-php-config=path to php-config % make % make install % make test php.ini file: You can update your php.ini file to automatically load your extension. Add the following to your php.ini file. [xhprof] extension=xhprof.so ; ; directory used by default implementation of the iXHProfRuns ; interface (namely, the XHProfRuns_Default class) for storing ; XHProf runs. ; xhprof.output_dir=directory_for_storing_xhprof_runs xhprof的使用也很简单,只要将需要监控的脚本放在 xhprof_enable() 和 xhprof_disable() 中间,就可以得到相应的结果,同时也提供了一些参数可以让我们设置是否监控 Memory, CPU 的使用,是否监控PHP内置的函数,从 0.9.2 之后,还可以设置跳过一些特定的函数。 XHProf 生成的数据,可以用 XHProf UI 来进行简单的显示。 XHProf使用也很简单,下面是一个官方的例子: ?php function bar($x) { ? if ($x 0) { ??? bar($x - 1); ? } } function foo() { ? for ($idx = 0; $idx 2; $idx++) { ??? bar($idx); ??? $x = strlen(abc); ? } } xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY); foo(); $xhprof_data = xhpro

文档评论(0)

didala + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档