前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >怎么将Tideways的日志数据生成火焰图?

怎么将Tideways的日志数据生成火焰图?

作者头像
沈唁
发布2019-05-22 15:28:52
8850
发布2019-05-22 15:28:52
举报
文章被收录于专栏:沈唁志沈唁志

之前的一篇文章说了怎么安装TidewaysToolkitPHP代码进行性能分析

Toolkit生成的是树状图,如果要进行性能分析,可能并不好分析

所以我们可以将Tideways生成的日志数据转为火焰图(flame graph)

火焰图是一个性能分析的利器,并且可以和用户互动(生成是svg格式的矢量图),直观明了

鼠标悬浮

火焰的每一层都会标注函数名,鼠标悬浮时会显示完整的函数名、抽样抽中的次数、占据总抽样次数的百分比

点击放大

在某一层点击,火焰图会水平放大,该层会占据所有宽度,显示详细信息

左上角会同时显示”Reset Zoom”,点击该链接,图片就会恢复原样

搜索

按下Ctrl + F或者点击图中右上角的Search会显示一个搜索框,用户可以输入关键词或正则表达式,所有符合条件的函数名会高亮显示

由于Tideways的数据格式并不能直接生成火焰图,那么我们如何将其产生的数据转为可以生成flame graph火焰图的格式并生成火焰图呢

于是搞了一个扩展,使用composer进行安装

代码语言:javascript
复制
composer require sy-records/xhprof2flamegraph

安装完成后,vendor/bin目录下将有两个可执行脚本文件

一个可以将Tideways的数据转为可以生成火焰图的格式,并直接输出;一个可以生成火焰图

可以执行如下命令进行使用:

代码语言:javascript
复制
./vendor/bin/xhprof2flamegraph -f ./test.xhprof | ./vendor/bin/flamegraph.pl > out.svg

-f为指定Tideways生成的日志文件路径

其他的看Github 仓库

末尾再说一个清理的问题,保留 7 天数据,然后其他的可以删掉

排序,再取最后 7 行,删掉前面所有的行

代码语言:javascript
复制
ls | sort | head -n -7 | xargs -r rm -rf
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-05-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 鼠标悬浮
  • 点击放大
  • 搜索
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档