在生产环境中使用php性能测试工具xhprof
浏览:4378次 出处信息
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真是酷毙了,哪段代码成为瓶颈,一目了然。
建议继续学习:
- Xvfb+YSlow+ShowSlow搭建前端性能测试框架 (阅读:55008)
- 安全测试与渗透测试区别 (阅读:24420)
- Mysql监控指南 (阅读:20599)
- 分享一个JQUERY颜色选择插件 (阅读:13635)
- 使用Fiddler对手机应用进行抓包测试 (阅读:7949)
- 服务器性能测试工具推荐 (阅读:7494)
- 给Apache做压力测试时遇到的问题 (阅读:6758)
- WEB性能测试工具推荐 (阅读:6523)
- 可用性测试好助手——Morae软件的应用 (阅读:6337)
- 12款很棒的浏览器兼容性测试工具推荐 (阅读:5687)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:131个字符的php framework
后一篇:正则表达式简介及使用 >>
文章信息
- 作者:Volcano 来源: 某人的栖息地
- 标签: xhprof 工具 测试
- 发布时间:2009-10-27 08:58:40
建议继续学习
近3天十大热文
-
[928] WordPress插件开发 -- 在插件使用 -
[134] 解决 nginx 反向代理网页首尾出现神秘字 -
[52] 整理了一份招PHP高级工程师的面试题 -
[52] 如何保证一个程序在单台服务器上只有唯一实例( -
[51] 用 Jquery 模拟 select -
[50] 海量小文件存储 -
[50] Innodb分表太多或者表分区太多,会导致内 -
[50] 全站换域名时利用nginx和javascri -
[49] CloudSMS:免费匿名的云短信 -
[47] jQuery性能优化指南
