在API优化list中,公司客户系统的服务号客服有个获取聊天消息的接口getHistory请求时间很长,就去优化了下,记下过程。

一,配置环境,追踪使用Xdebug:

1、在https://xdebug.org/下载安装

2、修改php.ini,添加:

[Xdebug]
zend_extension=/alidata/server/php/lib/php/extensions/no-debug-non-zts-20100525/xdebug.so
xdebug.default_enable=on
xdebug.trace_output_dir="/tmp/xdebug"
xdebug.trace_output_name=trace.%c.%p
xdebug.profiler_enable_trigger=1
xdebug.profiler_output_dir="/tmp/xdebug"
xdebug.profiler_output_name="cachegrind.out.%s"

该配置将加载xdebug模块,并设置效能检测文件的输出路径trace_output_dir

3、重启PHP进程:php-fpm restart

二,获取分析结果

在要测试的接口上添加?XDEBUG_PROFILE=1即可触发效能检测,

http://xng.crm.jinxi.cn/admin/room/gethistory?XDEBUG_PROFILE=1

也可以使用谷歌浏览器的Xdebug Helper插件,请求接口前点击profile即可,插件会自动添加XDEBUG_PROFILE的cookie头

PHP xdebug API接口优化揪出了getimagesize这个鬼-LMLPHP

去tmp/xdebug即可拿到分析文件

PHP xdebug API接口优化揪出了getimagesize这个鬼-LMLPHP

下载qcachegrindwin  图形化分析工具:https://sourceforge.net/projects/qcachegrindwin/

下载该文件使用qcachegrindwin打开(注意把文件名改成callgrind.*)   (wincachegrind不能用下面有备注)

PHP xdebug API接口优化揪出了getimagesize这个鬼-LMLPHP

嗯???之前以为是DB读写占用了太长时间,这样看来是获取聊天历史时即时使用php换算getimagesize获取了图片的宽高占用了太长时间,查看PHP文档知道,这个函数需要先下载网络图片然后获取长宽信息,好吧,解决方案是上传图片时保存图片的宽高信息,获取记录是直接获取。

成果:接口从之前的1864ms缩短的581ms done!

PHP xdebug API接口优化揪出了getimagesize这个鬼-LMLPHP

注:

使用sourcefog下载的wincachegrind1.0.0.14版本无法打开分析文件。报错:"Cannot find target.",可能是与xdebug版本不匹配导致的。去github下载最新版本后可解决此问题。

v1.1.0.16 在github下载 https://github.com/ceefour/wincachegrind/releases/tag/1.1

PHP xdebug API接口优化揪出了getimagesize这个鬼-LMLPHP

后来发现wincachegrind1.0.0.14没有实现图形化很坑啊,

PHP xdebug API接口优化揪出了getimagesize这个鬼-LMLPHP

05-22 04:37