温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

PHP + xdebug分析代码性能瓶颈的案例

发布时间:2021-02-19 14:57:58 来源:亿速云 阅读:214 作者:小新 栏目:编程语言

小编给大家分享一下PHP + xdebug分析代码性能瓶颈的案例,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

PHP + xdebug 分析代码性能瓶颈

通常启用了xdebug插件,性能测试输出文件会伴随生成,通常是以cachegrind.out.xxxx 文件存在。

该文件可以通过第三方工具来进行代码性能分析。

但如果本地有多个项目/网站,所有的profile 都输出到一个文件中了,这样并不方便后面进行性能分析。

自定义profile 文件名称

可以通过配置xdebug.profiler_output_name 参数来设置输出文件名称,部分参数如下:

符号含义配置样例样例文件名
%c当前工作目录的crc32校验值cachegrind.out.%ccachegrind.out.1258863198
%p当前服务器进程的pidcachegrind.out.%pcachegrind.out.9685
%r随机数cachegrind.out.%rcachegrind.out.072db0
%s脚本文件名(注)cachegrind.out.%scachegrind.out._home_httpd_html_test_xdebug_test_php
%tUnix时间戳(秒)cachegrind.out.%tcachegrind.out.1179434742
%uUnix时间戳(微秒)cachegrind.out.%ucachegrind.out.1179434749_642382
%H$_SERVER['HTTP_HOST']cachegrind.out.%Hcachegrind.out.localhost
%R$_SERVER['REQUEST_URI']cachegrind.out.%Rcachegrind.out._test_xdebug_test_php_var=1_var2
%Ssession_id (来自$_COOKIE 如果设置了的话)cachegrind.out.%Scachegrind.out.c70c1ec2375af58f74b390bbdd2a679d
%%%字符cachegrind.out.%%cachegrind.out.%%

编辑php.ini 配置文件:

xdebug.profiler_output_name = cachegrind.out.%H

然后重启 php server。

在Mac 下,profile 文件存放于/var/tmp/目录中。

性能分析

在Mac 下,有MacCallGrind 和 qcachegrind 可以使用,不过前者是收费,直接通过Apple Store下载,后者是免费。需要手动安装。

安装graphviz,用来Call Graph功能:

$ brew install graphviz

安装 qcachegrind:

$ brew install qcachegrind

安装完成之后,就可以打开 qcachegrind 应用了,图形界面如下:

PHP + xdebug分析代码性能瓶颈的案例

其他

不过需要注意,开启了profile文件输出之后,如果本地项目多的话,很容易占用磁盘大面积空间,下图是我半年左右没有清理的状态:

PHP + xdebug分析代码性能瓶颈的案例PHP + xdebug分析代码性能瓶颈的案例

可以使用命令进行清理:

$ sudo rm -fr /private/var/tmp/cachegrind.out.*

看完了这篇文章,相信你对“PHP + xdebug分析代码性能瓶颈的案例”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI