Table des matières
php性能分析工具,php性能分析
一、前言
二、安装
三、php.ini配置
四、重启服务
五、使用方法
六、注意问题以及名词解释
七、参考资料
Maison 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>
Copier après la connexion

三、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>
Copier après la connexion

四、重启服务

<span><span>1</span> sudo /etc/init.d/<span>http restart
</span><span>2</span> 
<span>3</span> 查看phpinfo是否安装成功</span>
Copier après la connexion

五、使用方法

<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>
Copier après la connexion

  上边的代码使用了,给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>
Copier après la connexion

  名词解释

<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>
Copier après la connexion

七、参考资料

<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
Copier après la connexion

 

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Analyse des performances des processeurs Kirin 8000 et Snapdragon : comparaison détaillée des forces et des faiblesses Analyse des performances des processeurs Kirin 8000 et Snapdragon : comparaison détaillée des forces et des faiblesses Mar 24, 2024 pm 06:09 PM

Analyse des performances des processeurs Kirin 8000 et Snapdragon : comparaison détaillée des forces et des faiblesses Avec la popularité des smartphones et leurs fonctionnalités croissantes, les processeurs, en tant que composants essentiels des téléphones mobiles, ont également attiré beaucoup d'attention. L'une des marques de processeurs les plus courantes et les plus excellentes sur le marché est actuellement la série Kirin de Huawei et la série Snapdragon de Qualcomm. Cet article se concentrera sur l'analyse des performances des processeurs Kirin 8000 et Snapdragon et explorera la comparaison des forces et des faiblesses des deux sous divers aspects. Jetons d’abord un coup d’œil au processeur Kirin 8000. En tant que dernier processeur phare de Huawei, le Kirin 8000

Comparaison des performances : rapidité et efficacité du langage Go et du langage C Comparaison des performances : rapidité et efficacité du langage Go et du langage C Mar 10, 2024 pm 02:30 PM

Comparaison des performances : rapidité et efficacité du langage Go et du langage C Dans le domaine de la programmation informatique, les performances ont toujours été un indicateur important auquel les développeurs prêtent attention. Lors du choix d'un langage de programmation, les développeurs se concentrent généralement sur sa rapidité et son efficacité. Le langage Go et le langage C, en tant que deux langages de programmation populaires, sont largement utilisés pour la programmation au niveau système et les applications hautes performances. Cet article comparera les performances du langage Go et du langage C en termes de vitesse et d'efficacité, et démontrera les différences entre eux à travers des exemples de code spécifiques. Tout d’abord, jetons un coup d’œil à la présentation du langage Go et du langage C. Le langage Go est développé par G

Comment utiliser l'extension php XDebug pour un débogage puissant et une analyse des performances Comment utiliser l'extension php XDebug pour un débogage puissant et une analyse des performances Jul 28, 2023 pm 07:45 PM

Comment utiliser l'extension PHP Xdebug pour un débogage et une analyse des performances puissants Introduction : Dans le processus de développement d'applications PHP, le débogage et l'analyse des performances sont des liens essentiels. Xdebug est un puissant outil de débogage couramment utilisé par les développeurs PHP. Il fournit une série de fonctions avancées, telles que le débogage des points d'arrêt, le suivi des variables, l'analyse des performances, etc. Cet article explique comment utiliser Xdebug pour un débogage et une analyse des performances puissants, ainsi que quelques conseils et précautions pratiques. 1. Installez Xdebug et commencez à utiliser Xdebu

Comment effectuer une analyse des performances du code C++ ? Comment effectuer une analyse des performances du code C++ ? Nov 02, 2023 pm 02:36 PM

Comment effectuer une analyse des performances du code C++ ? Les performances sont une considération importante lors du développement de programmes C++. L'optimisation des performances de votre code peut améliorer la vitesse et l'efficacité de votre programme. Cependant, pour optimiser votre code, vous devez d’abord comprendre où se trouvent ses goulots d’étranglement en termes de performances. Pour trouver le goulot d'étranglement des performances, vous devez d'abord effectuer une analyse des performances du code. Cet article présentera certains outils et techniques d'analyse des performances du code C++ couramment utilisés pour aider les développeurs à détecter les goulots d'étranglement des performances dans le code à des fins d'optimisation. Outil de profilage utilisant l'outil de profilage

Outils et techniques pour l'optimisation du code et l'analyse des performances en JavaScript Outils et techniques pour l'optimisation du code et l'analyse des performances en JavaScript Jun 16, 2023 pm 12:34 PM

Avec le développement rapide de la technologie Internet, JavaScript, en tant que langage frontal largement utilisé, reçoit de plus en plus d'attention. Cependant, lors du traitement de grandes quantités de données ou d'une logique complexe, les performances de JavaScript seront affectées. Afin de résoudre ce problème, nous devons maîtriser certains outils et techniques d’optimisation du code et d’analyse des performances. Cet article vous présentera certains outils et techniques d’optimisation du code JavaScript et d’analyse des performances couramment utilisés. 1. Optimisation du code pour éviter les variables globales : les variables globales occuperont plus

Comment utiliser les outils d'analyse des performances pour analyser et optimiser les fonctions Java ? Comment utiliser les outils d'analyse des performances pour analyser et optimiser les fonctions Java ? Apr 29, 2024 pm 03:15 PM

Les outils d'analyse des performances Java peuvent être utilisés pour analyser et optimiser les performances des fonctions Java. Choisissez des outils d'analyse de performances : JVisualVM, VisualVM, JavaFlightRecorder (JFR), etc. Configurez les outils d'analyse des performances : définissez le taux d'échantillonnage, activez les événements. Exécuter la fonction et collecter des données : exécutez la fonction après avoir activé l'outil de profilage. Analysez les données de performances : identifiez les indicateurs de goulot d'étranglement tels que l'utilisation du processeur, l'utilisation de la mémoire, le temps d'exécution, les points chauds, etc. Optimiser les fonctions : utilisez des algorithmes d'optimisation, refactorisez le code, utilisez la mise en cache et d'autres technologies pour améliorer l'efficacité.

Conseils de développement C++ : Comment effectuer une analyse des performances du code C++ Conseils de développement C++ : Comment effectuer une analyse des performances du code C++ Nov 22, 2023 pm 08:25 PM

En tant que développeur C++, l'optimisation des performances est l'une de nos tâches incontournables. Afin d'améliorer l'efficacité d'exécution et la vitesse de réponse du code, nous devons comprendre les méthodes d'analyse des performances du code C++ afin de mieux déboguer et optimiser le code. Dans cet article, nous vous présenterons certains outils et techniques d’analyse des performances du code C++ couramment utilisés. Options de compilation Le compilateur C++ fournit des options de compilation qui peuvent être utilisées pour optimiser l'efficacité d'exécution du code. Parmi elles, l’option la plus couramment utilisée est -O, qui indique au compilateur d’optimiser le code. Normalement, nous définirions

Stratégies d'analyse et d'optimisation des performances des files d'attente Java Queue Stratégies d'analyse et d'optimisation des performances des files d'attente Java Queue Jan 09, 2024 pm 05:02 PM

Analyse des performances et stratégie d'optimisation de JavaQueue Résumé de la file d'attente : La file d'attente (file d'attente) est l'une des structures de données couramment utilisées en Java et est largement utilisée dans divers scénarios. Cet article abordera les problèmes de performances des files d'attente JavaQueue sous deux aspects : l'analyse des performances et les stratégies d'optimisation, et donnera des exemples de code spécifiques. Introduction La file d'attente est une structure de données premier entré, premier sorti (FIFO) qui peut être utilisée pour implémenter le mode producteur-consommateur, la file d'attente des tâches du pool de threads et d'autres scénarios. Java fournit une variété d'implémentations de files d'attente, telles que Arr

See all articles