之前的一篇文章说了怎么安装Tideways
和Toolkit
对PHP
代码进行性能分析
Toolkit
生成的是树状图,如果要进行性能分析,可能并不好分析
所以我们可以将Tideways
生成的日志数据转为火焰图(flame graph
)
火焰图是一个性能分析的利器,并且可以和用户互动(生成是svg
格式的矢量图),直观明了
鼠标悬浮
火焰的每一层都会标注函数名,鼠标悬浮时会显示完整的函数名、抽样抽中的次数、占据总抽样次数的百分比
点击放大
在某一层点击,火焰图会水平放大,该层会占据所有宽度,显示详细信息
左上角会同时显示”Reset Zoom”,点击该链接,图片就会恢复原样
搜索
按下Ctrl + F
或者点击图中右上角的Search
会显示一个搜索框,用户可以输入关键词或正则表达式,所有符合条件的函数名会高亮显示
由于Tideways
的数据格式并不能直接生成火焰图,那么我们如何将其产生的数据转为可以生成flame graph
火焰图的格式并生成火焰图呢
于是搞了一个扩展,使用composer
进行安装
composer require sy-records/xhprof2flamegraph
安装完成后,vendor/bin
目录下将有两个可执行脚本文件
一个可以将Tideways
的数据转为可以生成火焰图的格式,并直接输出;一个可以生成火焰图
可以执行如下命令进行使用:
./vendor/bin/xhprof2flamegraph -f ./test.xhprof | ./vendor/bin/flamegraph.pl > out.svg
-f
为指定Tideways
生成的日志文件路径
其他的看Github仓库吧
末尾再说一个清理的问题,保留7天数据,然后其他的可以删掉
排序,再取最后7行,删掉前面所有的行
ls | sort | head -n -7 | xargs -r rm -rf
🙂 🙁 😳 😯 😮 😥 😡 😛 😕 😐 😎 😉 😈 😆 😀 真很滑稽
@西枫里博客 ???你想干啥