搜索
首页后端开发php教程Xdebug文档(六) 分析PHP脚本,_PHP教程
Xdebug文档(六) 分析PHP脚本,_PHP教程Jul 12, 2016 am 08:50 AM
phpxdebug内置分析分析器找到文档脚本

Xdebug文档(六) 分析PHP脚本,

分析PHP脚本Xdebug内置分析器能让你找到脚本中的瓶颈并用额外的工具诸如KcacheGrind或WinCacheGrind工具可视化。

介绍

Xdebug分析器是分析PHP代码和判断瓶颈或确定代码哪里运行过慢需要使用加速器的强大分析器。Xdebug2的分析器输出信息以cachegrind兼容文件形成表现。这能让你使用优秀的KcacheGrind工具(Linux,KDE)来分析数据。如果你用Linux你可以在你安装管理器安装它。

Windows下也有预编译的QcacheGrind二进制安装包可用(QCacheGrind 是KcacheGrind不捆绑KDE的版本)

如果你用Mac系统,这里有介绍如何安装QcacheGrind。

Windows用户也可以选择使用WinCacheGrind。但其功能与KcacheGrind不一样所以本文不在此介绍该软件。Xdebug2.3出版时,WinCacheGrind当前仍不支持cachegrind压缩功能和文件。

如果你不使用KDE(或不想用),kcachegrind包也携带perl脚本“ct_annotate”能分析跟踪文件输出ASCII。

开始分析

Php.ini内设置xdebug.profiler_enable设为1开启分析。该设置命令xdebug启用分析并写入到 xdebug.profiler_output_dir指定的目录中。而产生的文件名一般以”cachegrind.out”开头,然后结尾跟着以PHP(或apache)进程PID(进程ID)或包含初始调试脚本目录的crc32哈希值。确保你的xdebug.profiler_output_dir设置目录有足够的空间保存分析对复杂脚本分析生成庞大的分析数据。比如有500MB以上的复杂应用程序 eZ Publish。

你也可以通过 xdebug.profiler_enable_trigger 设为1手动开启分析器。当它设为1后,你能让分析器使用名为XDEBUG_PROFILE的变量利用到GET/POST 或者 COOKIE 值。 FireFox 2 扩展能用于开启debugger (参考 HTTP Debug Sessions) 也能用于使用该设置。为了触发器能合理地运行, xdebug.profiler_enable 需要设为0。

分析输出

当产生分析结果后,你就能利用 KCacheGrind打开它:

                       

一旦打开了文件,KCacheGrind会有不同的面板提供充足的信息让你参考。左侧你能看到"Flat Profile"面板列出所有脚本函数并以花费 时间为序,还包括了它的子函数时间。第二列"Self"显示该函数(不包括子函数)花费的时间,第三列"Called"指被调用的频度,最后一列”functions”显示函数名称。Xdebug改变PHP内部函数名并在函数名加前缀“php::”,而引用文件也在用指定的方式处理。呼叫include命令都跟随“::”和引用的文件名. 左侧截图你能看到"include::/home/httpd/ez_34/v..." 和内存函数示例"php::mysql_query"。头两列的数量能以百分数表示总运行时间的占比(看示例)或绝对时间(1单元代表1/1.000.000之一秒)。你可以用右边的按钮来切换这两种模式。

右边的面板包含上层和下层两面板。上层面板显示哪个函数调用了当前选择的函数(截图中"eztemplatedesignresource->executecompiledtemplate). 下层面板显示已选择的函数调用的函数列表。

上层面板的Cost列显示当前选择的函数在列表内被调用时花费的时间。该数字在Cost列通常是100%。下方面板Cost列显示在列表中调用的函数所花费的时间。在这列的数字当中,你绝不看到达100%执行时间的函数。

"All Callers" 和 "All Calls"显示不仅仅是函数分别执行的直接调用而且还显示函数更多的上下级关系。截图中的上层面板显示当前选择的函数调用的所有函数列,直接和间接关系的其他函数都在堆栈中间。(翻译能力有限……原句是这样的:The upper pane in the screenshot on the left shows all functions calling the current selected one, both directly and indirectly with other functions inbetween them on the stack.)“Distance”列代表有多少函数呼叫在列表当中,而当前选择 的为(-1)。如果两函数间有不同的距离,此外会显示一范围值(例如:“5-24”)。圆括号中的数字代表平均值。下方面板也是类似显示,但不同的是它显示当前选择的函数调用的所有函数信息,不管是直接还是间接的。

相关设置

 

xdebug.profiler_append

类型: integer, 默认值: 0

设为1时,分析文件工作在新的请求下映射到相同的文件时(取决于xdebug.profiler_output_name)不会下覆盖分析结果,而是分析信息附加到尾部形成新的分析文件。

 

xdebug.profiler_enable

类型: integer, 默认值: 0

开启Xdebug的分析器能在profile output directory目录中创建分析文件。这些文件能被KcacheGrind读取而可视化分析数据。该设置不能使用ini_set()在脚本中设置。如果你要选择性开启分析器,可以使用 xdebug.profiler_enable_trigger设置设为1代替使用。

 

xdebug.profiler_enable_trigger

类型: integer, 默认值: 0

设为1时,你就能使用XDEBUG_PROFILE的GET/POST参数或设置XDEBUG_RPOFILE的cookie值触发分析文件的产生。这些写入分析数到预定义的目录中,为了不上分析文件在每次请求中产生,你需要设置xdebug.profiler_enable 为0值。访问触发器可能过xdebug.profiler_enable_trigger_value配置。

 

xdebug.profiler_enable_trigger_value

类型: string, 默认值: "", 始于 Xdebug > 2.3

如xdebug.profiler_enable_trigger所述,该设置用于限制谁能利用XDEBUG_PROFILE功能。当改变原本的空字符串默认值后,cookie,GET或POST参数值需要匹配共享秘密集合并随设置开启分析器。

 

xdebug.profiler_output_dir

类型: string, 默认值: /tmp

该目录为分析文件输出的地方,请确保运行PHP的账户能对该目录有写入权限。该设置不能用ini_set()在脚本中设置。

 

xdebug.profiler_output_name

类型: string, 默认值: cachegrind.out.%p

该设置决定分析文件的名称,可使用格式标识符指定,类似于sprintf() 和strftime()。有几种标识符可格式化文件名。详见参考xdebug.trace_output_name说明。

 

相关函数

 

string xdebug_get_profiler_filename()

返回当前保存的分析信息的文件名称。

 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1134782.htmlTechArticleXdebug文档(六) 分析PHP脚本, 分析PHP脚本Xdebug内置分析器能让你找到脚本中的瓶颈并用额外的工具诸如KcacheGrind或WinCacheGrind工具可视化。...
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
PHP如何对接淘宝商品搜索API文档PHP如何对接淘宝商品搜索API文档Jul 01, 2023 pm 10:16 PM

PHP如何对接淘宝商品搜索API文档淘宝是中国最大的电子商务平台之一,拥有庞大的商品库存和用户群体。对于开发者来说,通过对接淘宝的API接口,可以获取商品信息、推广活动以及进行交易等功能,从而实现个性化的商业应用。本文将介绍如何使用PHP语言对接淘宝商品搜索API,帮助开发者快速构建自己的电商应用。第一步:注册成为淘宝开发者在开始之前,需要先注册成为淘宝开发

在生产服务器上启用XDebug会使PHP变慢吗?在生产服务器上启用XDebug会使PHP变慢吗?Sep 22, 2023 pm 10:41 PM

是的,像XDebug这样的调试器会降低PHP服务器的性能。这就是调试器不放置在服务器环境中的原因。它们部署在不同的环境中,以避免不必要的开销。调试消息无法在已处于生产阶段的应用程序中显示。当将调试行为添加到服务器上,调试引擎附加到PHP进程。它开始接收消息以在断点处停止,但这不是必需的行为,因为它会给其他进程带来高性能打击,从而停止PHP解析器。另一方面,当调试器安装后,它们往往会在服务器中打开端口,因为它们不打算在生产环境中使用。在服务器中打开端口就像为黑客打开一扇窥探之门一样糟糕。

ThinkPHP6文档详解:掌握框架的核心ThinkPHP6文档详解:掌握框架的核心Jun 20, 2023 pm 09:14 PM

ThinkPHP6是一款基于PHP语言开发的Web应用框架,该框架一经推出就受到了广泛的欢迎和使用,目前已经成为国内最流行的一款PHP框架之一。在这篇文章中,我们将深入探讨ThinkPHP6框架的核心,帮助读者更好地掌握该框架。一、框架的概述ThinkPHP6是一个企业级的开发框架,它采用MVC(Model-View-Controller)模式进行开发,拥有

PHP8.0中的调试库:XdebugPHP8.0中的调试库:XdebugMay 14, 2023 am 08:09 AM

在PHP开发中,调试是不可避免的部分。为了帮助开发者更易于调试自己的代码,PHP8.0在其调试库中引入了一个非常有用的工具:Xdebug。本文将介绍Xdebug的一些主要功能,以及如何使用它来简化PHP调试的过程。Xdebug是一款开源调试工具,可以在PHP应用程序中捕获错误,并提供详细的错误堆栈跟踪信息,以及正在使用的变量。它可以帮助开发人员检测和解决代码

如何使用Hyperf框架进行API文档生成如何使用Hyperf框架进行API文档生成Oct 20, 2023 am 08:24 AM

如何使用Hyperf框架进行API文档生成引言:随着互联网的快速发展,API(ApplicationProgrammingInterface)已经成为了不可或缺的一部分,它可以将不同的应用程序连接起来,实现数据的共享与交互。对于开发团队来说,良好的API文档是保证团队协作的重要工具。本文将介绍如何利用Hyperf框架来生成清晰、易用的API文档,通过具体

在ThinkPHP6中使用Xdebug调试技术在ThinkPHP6中使用Xdebug调试技术Jun 20, 2023 pm 09:14 PM

ThinkPHP6是一个流行的PHP框架,它使用了多种技术让开发变得更加便利。其中一个技术是调试工具,如Xdebug。在这篇文章中,我们将探讨如何在ThinkPHP6中使用Xdebug进行调试。安装与配置Xdebug在开始使用Xdebug前,首先需要安装和启用它。在php.ini文件中,可以添加以下配置:[xdebug]zend_extension=x

Java文档解读:Short类的toHexString()方法功能解析Java文档解读:Short类的toHexString()方法功能解析Nov 03, 2023 am 11:57 AM

Java文档解读:Short类的toHexString()方法功能解析在Java编程中,我们经常需要进行数值的转换和处理。Short类是Java中的一个包装类,用于处理short类型的数据。其中,Short类提供了一个toHexString()方法,用于将short类型的数据转换为十六进制形式的字符串。本文将对toHexString()方法的功能进行解析,并

学习Go语言文档中的log.Println函数实现日志打印学习Go语言文档中的log.Println函数实现日志打印Nov 03, 2023 am 09:08 AM

Go语言提供了一个log包,用于实现日志打印。其中,log.Println函数是一种常用的打印日志的方式,它可以输出日志信息,并且带有时间戳和文件名等基本信息,方便于后续的分析和处理。下面,我们将介绍如何使用log.Println函数打印日志,并且给出具体的代码示例,方便读者学习和应用。首先,我们需要导入log包,代码如下:import"log&

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。