php扩展xdebug安装以及用kcachegrind系统分析

2024-04-02 14:15:39

一:安装

安装方法一:编译安装

1、下载PHP的XDebug扩展,网址:http://xdebug.org/
# wget http://pecl.php.net/get/xdebug-2.1.2.tgz
# tar -xzf xdebug-2.1.2.tgz
# xdebug-2.1.2
# cd xdebug-2.1.2
# /usr/local/php/bin/phpize
# ./configure --enable-xdebug --with-php-config=/usr/local/php/bin/php-config
# make && make install

不需要自己拷贝xdebug.so了,下面可以省。
# cp modules/xdebug.so /usr/local/php/lib/php/extensions/no-debug-non-zts-20060613

注:/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/不同的PHP版本路径不同,也不一定要放在该路径,可以在zend_extension_ts中自行指定xdebug.so所在位置。

================================================

安装方法二:自动安装

http://pecl.php.net/package/xdebug

#  /usr/local/php/bin/pecl install xdebug

安装成功

windows下安装:

需要注意使用custom installation instructions. 将你的phpinfo生成的内容放进去测试 看看下载那个dll

===============================================

二:修改php配置模块

1.配置

修改php.ini,去除PHP加速模块,增加以下配置信息支持XDebug扩展

手动安装

[Xdebug]  
zend_extension_ts="/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/xdebug.so"

xdebug.profiler_enable=on 
xdebug.trace_output_dir="/tmp/xdebug" 
xdebug.profiler_output_dir="/tmp/xdebug"

zend_extension也可以

自动安装

[Xdebug]

extension=xdebug.so

xdebug.profiler_enable=on
xdebug.trace_output_dir="/tmp/xdebug"
xdebug.profiler_output_dir="tmp/xdebug"

Windows下配置

用phpinfo()查看php配置文件位置,增加:

extension=php_xdebug-2.2.0-5.3-vc9.dll[Xdebug];开启自动跟踪
xdebug.auto_trace = On
;开启异常跟踪
xdebug.show_exception_trace = On
;开启远程调试自动启动
xdebug.remote_autostart = On
;开启远程调试
xdebug.remote_enable = On
;收集变量
xdebug.collect_vars = On
;收集返回值
xdebug.collect_return = On
;收集参数
xdebug.collect_params = Onxdebug.remote_enable=on
xdebug.remote_handler=dbgp
xdebug.remote_host=127.0.0.1
xdebug.remote_port=9000  xdebug.profiler_enable=on
;xdebug.trace_output_name="%H.%s"
xdebug.trace_output_dir="E:\PHPnow\xdebug"
xdebug.profiler_output_dir="E:\PHPnow\xdebug"

------------------------------

2.权限

# mkdir -p /tmp/xdebug
# chmod 755 /tmp/xdebug

注意这个一定要
chown www:www /tmp/xdebug

当前PHPFPM的用户组在PHPFPM的配置文件

; Unix user/group of processes
; Note: The user is mandatory. If the group is not set, the default user's group
;       will be used.
user = nobody
group = nobody

这样就是,没有这个不会在tmp目录生成文件

# chown nobody:nobody /tmp/xdebug

正常的运行PHP会生成调试文件

-rw-r--r-- 1 nobody nobody 5758239 Oct 27 14:56 cachegrind.out.29270

-----------------------------

3.重启
/usr/local/apache/bin/apachectl  restart

说明:如果phpinfo()没有打印这个信息说明没有配置正确!

------------------------------

4.停用

说明:如果不分析系统一定要记得关闭xdebug.profiler不然会生成许多文件

xdebug.profiler_enable=off

====================================

三:分析系统

1.访问你的网站

将首页上各种链接点击几遍,XDebug在/tmp/xdebug目录生成文件

2.使用图形分析工具wincachedgrind分析生成的文件

下载地址:http://sourceforge.net/projects/wincachegrind/files/

3.下载图形化工具kcachegrind在windows下的可执行版

下载地址http://sourceforge.net/projects/precompiledbin/files

用kcachegrind来看会更形象,注意需要修改从linux中执行的文件的php文件路径,这样就可以了sourcecode.

查看代码执行顺序

更复杂的代码:

<?phpdefine( 'BOOSTER', 5 );define( 'CAPSULE', 2 );define( 'MINUTE', 60 );define( 'STAGE', 3 );define( 'PRODUCTION', 1000 );class Part {function Part() {$this->build( MINUTE );}function build( $delay = 0 ) {if ( $delay <= 0 )return;while ( $delay-- > 0 ) {}}}class Capsule extends Part {function Capsule() {parent::Part();$this->build( CAPSULE * MINUTE );}}class Booster extends Part {function Booster() {parent::Part();$this->build( BOOSTER * MINUTE );}}class Stage extends Part {function Stage() {parent::Part();$this->build( STAGE * MINUTE );}}class SpaceShip {var $booster;var $capsule; var $stages;function SpaceShip( $numberStages = 3 ) {$this->booster = new Booster();$this->capsule = new Capsule();$this->stages = array();while ( $numberStages-- >= 0 ) {$stages[$numberStages] = new Stage();}}}$toys = array();$count = PRODUCTION;while ( $count-- >= 0  ) {$toys[] = new SpaceShip( 2 );}
?><html>
<head>
<title>
Toy Factory Output
</title>
</head>
<body><h1>Toy Production</h1><p>Built <? echo PRODUCTION . ' toys' ?></p>
</body>
</html>

分析日志

其他使用参考:xdebug基本使用

===================================

参考

"

为 PHP 应用提速、提速、再提速!,第 2 部分: 分析 PHP 应用程序以查找、诊断和加速运行缓慢的代码

http://www.ibm.com/developerworks/cn/opensource/os-php-fastapps2/index.html

http://hi.baidu.com/%D4%E7%B9%C8%C9%E7%C7%F8/blog/item/d8fedafb7843c66b024f56cb.html

使用Xdebug跟踪代码执行

http://book.51cto.com/art/200906/126516.htm

KCacheGrind windows 系統下的代替方案

  1. WinCacheGrind
  2. 可分析由xdebug產出的cachegrind.xxx檔,簡易版的kcachegrind。

  3. windows port of kcachegrind
  4. 由原linux的kcachegrind,重新編譯在windows上可執行版,功能與linux kcachegrind相同。

  5. Webgrind
  6. 網頁版的callgrind,搭配xdebug可做即時線上做php script profile。

===================================

NetBeans配置Xdebug

http://blog.csdn.net/21aspnet/article/details/6754034

===================================

另外还有一个扩展也很好:

http://pecl.php.net/package/xhprof

安装参考:

http://www.phpv5.com/blog/archives/66

参考:

用 kcachegrind 调优 squid 2.7 笔记

http://blog.sunyixing.com/archives/378

php扩展xdebug安装以及用kcachegrind系统分析相关推荐

  1. php扩展xdebug安装

    为什么80%的码农都做不了架构师?>>>    xdebug下载 https://xdebug.org 下载对应的文件即可 windows下安装 php5.2自带xdebug,在ex ...

  2. php调试工具xdebug安装配置教程,PHP 7安装调试工具Xdebug扩展的方法教程

    PHP 7安装调试工具Xdebug扩展的方法教程 前言 说到PHP代码调试,对于有经验的PHPer,通过echo.print_r.var_dump函数,或PHP开发工具zend studio.edit ...

  3. PHP - Xdebug安装 - 学习/实践

    1.应用场景 主要用于学习和安装xdebug扩展. 2.学习/操作 1. 文档 Xdebug - Debugger and Profiler Tool for PHP Xdebug: Document ...

  4. php amqp扩展安装,php扩展AMQP,安装报错解决

    接下来来安装php扩展AMQP,安装了它以后,才能用PHP操作rabbitmq. wget https://pecl.php.net/get/amqp-1.4.0.tgz tar -zxvf amqp ...

  5. 火绒规则 禁止所有软件的安装_软件: Firefox 将禁止扩展静默安装

    Mozilla 宣布 Firefox 将禁止被称为 Sideloading 的扩展静默安装方法.计划在 2020 年 3 月 10 日释出的 Firefox v74 将停止支持 Sideloading ...

  6. GraphicsMagick扩展配置安装

    GraphicsMagick 是一个很高效的图片处理工具,跟 ImageMagic 类似,接口也几乎跟 ImageMagic 全部兼容.事实上,GraphicsMagick是从 ImageMagick ...

  7. centos php memcache扩展,CentOS安装php5的memcache扩展

    扩展包下载地址:http://pecl.php.net/package-stats.php 目前的稳定包是:http://pecl.php.net/get/memcache-2.2.6.tgz 假如你 ...

  8. php扩展swoole安装,php 安装swoole扩展

    步骤 1.在swoole官网 https://www.swoole.com/ 下载需要安装的版本如通过git clone下载: git clone https://gitee.com/swoole/s ...

  9. zlib 离线安装_黑板派Python扩展库安装与常见问题解决完整指南

    点击蓝字 ! 关注我们 "Python小屋"编程比赛正式开始 推荐图书: <Python程序设计(第3版)>,(ISBN:978-7-302-55083-9),董付国, ...

最新文章

  1. 发那科机器人控制柜示教器不通电_分享ABB机器人控制柜和本体的接线,给刚入门机器人的新人...
  2. 1057. Stack (30)
  3. gcore java_获取一直FullGC下的java进程HeapDump的小技巧
  4. 用C语言编程实现矩形波信号,信号与系统综合设计性实验
  5. 这才是智能手表该有的样子 HUAWEI WATCH 2评测
  6. 实验一个最小的PYTHON服务器编程
  7. fork与操作文件的系统调用问题
  8. 如何成为有思想、创新的程序员
  9. JVM系列之:再谈java中的safepoint
  10. oracle 取时间比较,Oracle最大日期获取方法
  11. 路径.git下的文件
  12. 企业内部自建用户行为分析平台全过程
  13. Linux IPC实践(7) --Posix消息队列
  14. Microstrategy CEO:比特币是一种货币资产 正在迅速取代黄金作为价值存储
  15. 异常处理和代码复用在python自动化运维中的使用(eNSP模拟器)
  16. homework2:根据已知代码,回答问题
  17. js 设置div超出宽度隐藏_【CSS/JS】如何实现单行/多行文本溢出的省略(...)--绕过坑道的正确姿势...
  18. Python 数据处理数据挖掘(五):线性回归
  19. graphpad如何检测方差齐_【求助】急求如何用Graphpad Prism6 做析因设计方差分析?谢谢各位大神...
  20. ubuntu14.04+cuda8.0(gtx1080)下tensorflow的安装

热门文章

  1. ecm工作原理 usb_(转)USB中CDC-ECM的了解和配置
  2. 下怎么运行sh脚本_基于CentOS7系统添加自定义脚本服务及参数说明,附实例
  3. OpenCV中的光流及视频特征点追踪
  4. LabVIEW目标测量方法(基础篇—12)
  5. 1024,不讲技术,来一套程序员续命操~
  6. Linux那些事儿之我是Sysfs(7)dentry与inode
  7. 【深度学习】(2) 数据加载,前向传播2,附python完整代码
  8. OpenCV 遇到的问题
  9. C语言网络编程:bind函数详解
  10. 第八章 泛型程序设计