toolkit是tideway官方提供的性能分析的命令行工具。如果你只是本地开发调试接口性能,不想安装xhgui,那么使用toolkit就足够了.
安装
安装tideways拓展
git clone https://github.com/tideways/php-xhprof-extension.git cd php-profiler-extension phpize ./configure make && make install
在php.ini中加入
extension=tideways_xhprof.so
重启php-fpm
立即学习“PHP免费学习笔记(深入)”;
service php-fpm restart
toolkit安装
go get github.com/tideways/toolkit # 安装graphviz # macOS brew install graphviz # ubuntu sudo apt-get install -y graphviz
设置别名
alias tk=toolkit
tideways+toolkit
代码埋点
在程序入口中加入
if (extension_loaded('tideways_xhprof')) {
tideways_xhprof_enable(TIDEWAYS_XHPROF_FLAGS_CPU | TIDEWAYS_XHPROF_FLAGS_MEMORY);
}
// 你的代码
application();
if (extension_loaded('tideways_xhprof')) {
$data = tideways_xhprof_disable();
file_put_contents(
sprintf('%s/app.xhprof', '/path/to'),
json_encode($data)
);
}执行下代码,然后就会生成/path/to/app.xphrof
性能分析
tk analyze-xhprof /path/to/app.xphrof

默认性能分析的指标是wt_excl,其他的指标有
1.wt 调用时长,包括子函数
采用 php+mysql 数据库方式运行的强大网上商店系统,执行效率高速度快,支持多语言,模板和代码分离,轻松创建属于自己的个性化用户界面 v3.5更新: 1).进一步静态化了活动商品. 2).提供了一些重要UFT-8转换文件 3).修复了除了网银在线支付其它支付显示错误的问题. 4).修改了LOGO广告管理,增加LOGO链接后主页LOGO路径错误的问题 5).修改了公告无法发布的问题,可能是打压
0
2.excl_wt 调用时长,不包括子函数
3.cpu CPU调用时长,包括子函数
4.excl_cpu CPU调用时长,不包括子函数
5.memory 内存消耗(字节),包括子函数
6.excl_memory 内存消耗(字节),不包括子函数
7.io io时长,包括子函数
8.excl_io io时长,不包括子函数
生成性能瓶颈图
tk generate-xhprof-graphviz /path/to/app.xhprof dot -Tpng callgraph.dot > callgraph.png

显示的指标有
1.函数名
2.Inc 函数运行时间,包括子函数
3.Excl 函数运行时间,不包括子函数
4.total calls 总调用次数
以上就是tideways+toolkit对php代码进行性能分析的详细内容,更多请关注php中文网其它相关文章!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号