목차
php性能分析工具,php性能分析
一、前言
二、安装
三、php.ini配置
四、重启服务
五、使用方法
六、注意问题以及名词解释
七、参考资料
php教程 php手册 php性能分析工具,php性能分析

php性能分析工具,php性能分析

Jun 13, 2016 am 08:55 AM
성능 분석

php性能分析工具,php性能分析

一、前言

  有用的东西还是记录下来吧,也方便以后的查询;这次记录一下xhprof的安装使用;

  xhprof是facebook开源出来的一个php轻量级的性能分析工具,跟Xdebug类似,但性能开销更低,

  还可以用在生产环境中,也可以由程序开 关来控制是否进行profile。

二、安装

<span>1.    wget http:<span>//</span><span>pecl.php.net/get/xhprof-0.9.3.tgz  </span>

2.    tar zxf xhprof-0.9.3.<span>tgz  

</span>3.    cd xhprof-0.9.3/<span>extension

</span>4.    /usr/bin/<span>phpize 
     (php版本安装后生成的phpize文件,可根据phpinfo查看,所以php版本不同,生成的phpize也不同,此步骤主要生成configure文件)

</span>5.    ./configure  &ndash;with-php-config=/usr/bin/php-<span>config  
    (php</span>-<span>config的路径,也是php安装后生成的文件)  

</span>6.<span>    make  

</span>7.<span>    sudo make install 
    (会自动将生成的扩展文件拷贝到扩展目录中</span>/usr/lib64/php/<span>modules)

    当然具体的php文件的目录,每个人不尽相同,可根据phpinfo查询</span></span>
로그인 후 복사

三、php.ini配置

<span><span>1</span> <span>根据phpinfo找到 extension_dir的目录
</span><span>2</span> (/etc/php.d/xhprof.<span>ini)
</span><span>3</span> 
<span>4</span> <span>添加一下内容:
</span><span>5</span> 
<span>6</span> extension=xhprof.<span>so
</span><span>7</span> xhprof.output_dir=/tmp/xhprof <span>//</span><span>xhprof的分析日志</span></span>
로그인 후 복사

四、重启服务

<span><span>1</span> sudo /etc/init.d/<span>http restart
</span><span>2</span> 
<span>3</span> 查看phpinfo是否安装成功</span>
로그인 후 복사

五、使用方法

<span><span> 1</span> <span>开头:
</span><span> 2</span> xhprof_enable(); <span>//</span><span>开启监测  
</span><span> 3</span> <span>//xhprof_enable(XHPROF_FLAGS_NO_BUILTINS); 不记录内置的函数  
</span><span> 4</span> <span>//xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMORY);  同时分析CPU和Mem的开销  
</span><span> 5</span> 
<span> 6</span> <span>//要测试的代码</span>
<span> 7</span> ...
<span> 8</span> ...
<span> 9</span> ...
<span>10</span> 
<span>11</span> <span>结尾:
</span><span>12</span> <span>$xhprof_data</span> = xhprof_disable();  <span>//</span><span>停止监测,返回运行数据</span>
<span>13</span> <span>$xhprof_root</span> = '/(xhprof的虚拟主机目录)/'<span>;  
</span><span>14</span>  <span>//</span><span>引入当初安装到xhprof虚拟主机目录中的文件</span>
<span>15</span> <span>include_once</span> <span>$xhprof_root</span>."xhprof_lib/utils/xhprof_lib.php"<span>;  
</span><span>16</span> <span>include_once</span> <span>$xhprof_root</span>."xhprof_lib/utils/xhprof_runs.php"<span>;   
</span><span>17</span> <span>$xhprof_runs</span> = <span>new</span><span> XHProfRuns_Default();   
</span><span>18</span> <span>$run_id</span> = <span>$xhprof_runs</span>->save_run(<span>$xhprof_data</span>, "xhprof"<span>);
</span><span>19</span> <span>echo</span> '<a href="http://(xhprof的虚拟主机域名)/xhprof_html/index.php?run='.<span>$run_id</span>.'&source=xhprof" target="_blank">xhprof统计</a>'<span>;  </span></span>
로그인 후 복사

  上边的代码使用了,给xhprof设置虚拟主机的方法。

  把源码包中的 xhprof_html 和 xhprof_lib 文件夹拷贝到自己建立的虚拟目录中

  cp -r xhprof_html xhprof_lib /xxx/xhprof/ (此处目的是建立数据分析目录,可将此目录配置成虚拟主机访问)

  运行后,统计点击返回的 xhprof统计 链接,即可。

六、注意问题以及名词解释

  在显示的统计页面中,点[View Full Callgraph]图形化显示(最大的性能问题会用红色标出,其次是黄色);

  点击后,可能提示错误消息,执行以下命令即可

<span><span>1</span> yum install -<span>y graphviz
</span><span>2</span> yum install graphviz-gd</span>
로그인 후 복사

  名词解释

<span><span> 1</span>     <span>Function</span><span> Name 函数名
</span><span> 2</span> <span>    Calls 调用次数
</span><span> 3</span>     Calls%<span> 调用百分比
</span><span> 4</span>     Incl. Wall <span>Time</span><span> (microsec) 调用的包括子函数所有花费时间 以微秒算(一百万分之一秒)
</span><span> 5</span>     IWall%<span> 调用的包括子函数所有花费时间的百分比
</span><span> 6</span>     Excl. Wall <span>Time</span> (microsec) 函数执行本身花费的时间,不包括子树执行时间,<span>以微秒算(一百万分之一秒)
</span><span> 7</span>     EWall%<span> 函数执行本身花费的时间的百分比,不包括子树执行时间
</span><span> 8</span>     Incl. CPU(microsecs) 调用的包括子函数所有花费的cpu时间。减Incl.<span> Wall Time即为等待cpu的时间
</span><span> 9</span>     减Excl.<span> Wall Time即为等待cpu的时间
</span><span>10</span>     ICpu% Incl.<span> CPU(microsecs)的百分比
</span><span>11</span>     Excl. CPU(microsec) 函数执行本身花费的cpu时间,不包括子树执行时间,<span>以微秒算(一百万分之一秒)。
</span><span>12</span>     ECPU% Excl.<span> CPU(microsec)的百分比
</span><span>13</span>     Incl.<span>MemUse(bytes) 包括子函数执行使用的内存。
</span><span>14</span>     IMemUse% Incl.<span>MemUse(bytes)的百分比
</span><span>15</span>     Excl.MemUse(bytes) 函数执行本身内存,<span>以字节算
</span><span>16</span>     EMemUse% Excl.<span>MemUse(bytes)的百分比
</span><span>17</span>     Incl.PeakMemUse(bytes) Incl.<span>MemUse的峰值
</span><span>18</span>     IPeakMemUse% Incl.<span>PeakMemUse(bytes) 的峰值百分比
</span><span>19</span>     Excl.PeakMemUse(bytes) Excl.<span>MemUse的峰值
</span><span>20</span>     EPeakMemUse% EMemUse% 峰值百分比</span>
로그인 후 복사

七、参考资料

<span>1</span> <span> http://blog.csdn.net/maitiandaozi/article/details/8896293
</span><span>2</span> <span> http://www.cnblogs.com/wangtao_20/archive/2011/03/16/1986508.html
</span><span>3</span> <span> http://www.cnblogs.com/wangtao_20/archive/2013/09/13/3320497.html
</span><span>4</span>  
<span>5</span> <span> http://avnpc.com/pages/profiler-php-performance-online-by-xhprof
</span><span>6</span> <span> http://www.ituring.com.cn/article/132392
</span><span>7</span>  http://www.ituring.com.cn/article/133062?utm_source=tuicool
로그인 후 복사

 

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Kirin 8000 및 Snapdragon 프로세서의 성능 분석: 강점과 약점의 세부 비교 Kirin 8000 및 Snapdragon 프로세서의 성능 분석: 강점과 약점의 세부 비교 Mar 24, 2024 pm 06:09 PM

Kirin 8000 및 Snapdragon 프로세서의 성능 분석: 강점과 약점의 세부 비교

성능 비교: Go 언어와 C 언어의 속도 및 효율성 성능 비교: Go 언어와 C 언어의 속도 및 효율성 Mar 10, 2024 pm 02:30 PM

성능 비교: Go 언어와 C 언어의 속도 및 효율성

강력한 디버깅 및 성능 분석을 위해 PHP 확장 XDebug를 사용하는 방법 강력한 디버깅 및 성능 분석을 위해 PHP 확장 XDebug를 사용하는 방법 Jul 28, 2023 pm 07:45 PM

강력한 디버깅 및 성능 분석을 위해 PHP 확장 XDebug를 사용하는 방법

C++ 코드의 성능 분석을 수행하는 방법은 무엇입니까? C++ 코드의 성능 분석을 수행하는 방법은 무엇입니까? Nov 02, 2023 pm 02:36 PM

C++ 코드의 성능 분석을 수행하는 방법은 무엇입니까?

JavaScript의 코드 최적화 및 성능 분석을 위한 도구 및 기술 JavaScript의 코드 최적화 및 성능 분석을 위한 도구 및 기술 Jun 16, 2023 pm 12:34 PM

JavaScript의 코드 최적화 및 성능 분석을 위한 도구 및 기술

성능 분석 도구를 사용하여 Java 기능을 분석하고 최적화하는 방법은 무엇입니까? 성능 분석 도구를 사용하여 Java 기능을 분석하고 최적화하는 방법은 무엇입니까? Apr 29, 2024 pm 03:15 PM

성능 분석 도구를 사용하여 Java 기능을 분석하고 최적화하는 방법은 무엇입니까?

Java Queue 큐 성능 분석 및 최적화 전략 Java Queue 큐 성능 분석 및 최적화 전략 Jan 09, 2024 pm 05:02 PM

Java Queue 큐 성능 분석 및 최적화 전략

Java로 구현된 Quick Sort 알고리즘과 효율성 평가 Java로 구현된 Quick Sort 알고리즘과 효율성 평가 Feb 18, 2024 pm 03:38 PM

Java로 구현된 Quick Sort 알고리즘과 효율성 평가

See all articles