xhprof 是facebook 开源出来的一个 php 性能测试工具,也可以称之为 profile 工具,这个词不知道怎么翻译才比较达意。跟之前一直使用的 xdebug 相比,有很多类似之处。以前对 xdebug 有一些记录还可以供参考,但是它的缺点是对性能影响太大,即便是开启了 profiler_enable_trigger 参数,用在生产环境中也是惨不忍睹,cpu 立刻就飙到 high。

而 xhprof 就显得很轻量,是否记录 profile 可以由程序控制,因此,用在生产环境中也就成为一种可能。在它的文档上可以看到这样一种用法:

以万分之一的几率启用 xhprof,平时悄悄的不打枪。

if (mt_rand(1, 10000) == 1) {
    xhprof_enable(XHPROF_FLAGS_MEMORY);
    $xhprof_on = true;
}

在程序结尾处调用方法保存profile

if ($xhprof_on) {
// stop profiler
$xhprof_data = xhprof_disable();

// save $xhprof_data somewhere (say a central DB)

}

也可以用 register_shutdown_function 方法指定在程序结束时保存 xhprof 信息,这样就免去了结尾处判断,给个改写的不完整例子:

if (mt_rand(1, 10000) == 1) {
    xhprof_enable(XHPROF_FLAGS_MEMORY);
    register_shutdown_function(create_funcion(”, “$xhprof_data = xhprof_disable(); save $xhprof_data;”));
}

至于日志,我暂时用的是最土的文件形式保存,定期清除即可。

BTW:  xhprof  生成的图形方式 profile 真是酷毙了,哪段代码成为瓶颈,一目了然。