Utilisez XHProf pour rechercher des instances de goulots d'étranglement des performances PHP

小云云
Libérer: 2023-03-17 21:34:01
original
1640 Les gens l'ont consulté

Les goulots d'étranglement en matière de performances font généralement référence aux applications nouvellement développées par les développeurs.

Par exemple,

Une application développée en Java ou C et déployée sur un serveur d'applications pour traiter les demandes de transactions des utilisateurs.

Par exemple,

Un développeur a développé un programme de traitement des paiements. Lors des tests, il a été constaté que

ce programme de traitement des paiements ne parvenait pas à traiter les demandes de paiement simultanées envoyées par les utilisateurs. , ne peut être traité qu'en série et ne peut pas être traité en parallèle, ce qui entraîne un temps de réponse de traitement très long pour les transactions de paiement. À l'heure actuelle, on peut considérer qu'un goulot d'étranglement dans les performances s'est produit dans l'application.

Cet article partagera avec vous un exemple d'utilisation de XHProf pour trouver les goulots d'étranglement des performances PHP. Il a une bonne valeur de référence et j'espère qu'il pourra aider tout le monde.

XHProf est une extension développée par Facebook pour tester les performances PHP. Cet article enregistre la méthode d'utilisation de XHProf pour optimiser les performances PHP et trouver les goulots d'étranglement des performances dans les applications PHP.

1. Installer l'extension Xhprof

//github上下载https://github.com/facebook/xhprof
unzip xhprof-master.zip 
cd xhprof-master/extension/
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config --enable-xhprof
make && make install
Copier après la connexion

2. Modifier php.ini

[xhprof]
extension=xhprof.so
xhprof.output_dir=/tmp
Copier après la connexion

Dans la configuration, xhprof.output_dir précise l'emplacement où le fichier de profil généré est généré. est stocké. Nous le spécifions comme /tmp.

3. Déplacez les fichiers pertinents dans le projet

//xhprof下载压缩包中的xhprof_html和xhprof_lib
cp -r xhprof-master/xhprof_html /usr/local/nginx/html/xhprof/
cp -r xhprof-master/xhprof_lib /usr/local/nginx/html/xhprof/
Copier après la connexion

Configurez un nom de domaine et le navigateur pourra accéder à http://will.com/xhprof/xhprof_html/index.php

server{
 listen 80;
 server_name will.com;
 location / {
  root /usr/local/nginx/html;
  index index.html;
 }
 location ~ \.php$ {
  root html;
  fastcgi_pass 127.0.0.1:9000;
  fastcgi_index index.php;
  fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  include  fastcgi_params;
 }
 }
Copier après la connexion

4. Installer graphivz

//需要安装graphviz否则查看性能图片时候会报failed to execute cmd: " dot -Tpng". stderr: `sh: dot: command not found '
yum -y install graphviz
Copier après la connexion

5. Écrire des fichiers de test

//入口文件的开始位置
xhprof_enable(XHPROF_FLAGS_MEMORY | XHPROF_FLAGS_CPU);

业务逻辑...

//业务逻辑结束后
$xhprof_data = xhprof_disable();
include_once "/usr/local/nginx/html/xhprof/xhprof_lib/utils/xhprof_lib.php"; 
include_once "/usr/local/nginx/html/xhprof/xhprof_lib/utils/xhprof_runs.php"; 
$objXhprofRun = new XHProfRuns_Default();//数据会保存在php.ini中xhprof.output_dir设置的目录去中 
$run_id = $objXhprofRun->save_run($xhprof_data, "test");
Copier après la connexion

Exemple de code complet (démo aléatoire de l'enveloppe rouge)

<?php
xhprof_enable(XHPROF_FLAGS_MEMORY | XHPROF_FLAGS_CPU);
function show($info)
{
 echo "<pre class="brush:php;toolbar:false">";
 print_r($info);
}

//不作数据校验
$rules = array(
 2=>array('min'=>1, 'max'=>10, 'chance'=>30),//金额:分 概率:百分之(默认为100%,不足100%按第一档计算)
 array('min'=>11, 'max'=>25, 'chance'=>60),
 array('min'=>26, 'max'=>50, 'chance'=>10),
 array('min'=>50, 'max'=>80, 'chance'=>0),
 array('min'=>80, 'max'=>100, 'chance'=>0),
);
$total_money = 10000;//红包总金额
$res = array();
while($total_money>0)
{
 $index = getLevel($rules);
 $money = setMoney($rules, $index);
 if ($money > $total_money)//金额不足
 {
 $money = $total_money;
 $total_money = 0;
 } else {
 $total_money -= $money;
 }
 $res[] = ($index+1)."---".$money;
}
echo show($res);
echo $total_money . "<br/>";
//1.先确定档次
function getLevel($rules)
{
 $level = array();
 $chance = 0;
 foreach($rules as $k=>$v)
 {
 if ($v['chance']>0)
 {
  $chance += $v['chance']*100;//扩大100倍
  $level[$k] = $chance;
 }
 }
 $index = 0;
 $rand_num = mt_rand(1, 10000);
 foreach($level as $k=>$v)
 {
 if ($rand_num <= $v)
 {
  $index = $k;
  break;
 }
 }
 return $index;
}
//2.确定档次之后,再确定金额
function setMoney($rules, $index)
{
 $money = mt_rand($rules[$index][&#39;min&#39;]*10000, $rules[$index][&#39;max&#39;]*10000)/10000;
 $money = ceil($money);
 $money > 1 && $money = $money -1;//防止出现免单情况
 return $money;
}
$xhprof_data = xhprof_disable();
include_once "/usr/local/nginx/html/xhprof/xhprof_lib/utils/xhprof_lib.php"; 
include_once "/usr/local/nginx/html/xhprof/xhprof_lib/utils/xhprof_runs.php"; 
$objXhprofRun = new XHProfRuns_Default();//数据会保存在php.ini中xhprof.output_dir设置的目录去中 
$run_id = $objXhprofRun->save_run($xhprof_data, "test");
echo "http://will.com/xhprof/xhprof_html/index.php?run=$run_id&source=test";//变量$runId是本次请求生成分析结果的id,最后我们输出了一个链接地址,使用改地址就可以看到本次请求的分析结果。
Copier après la connexion

6. Vérifiez les résultats de l'analyse

Exécutez d'abord le code commercial ;

Puis ouvrez http://will.com/xhprof/xhprof_html/index.php dans le navigateur, cliquez sur le bouton la dernière fois pour générer le fichier xhprof

Remarquez le lien View Full Callgraph au milieu, à travers lequel nous pouvons voir les résultats de l'analyse graphique

La partie rouge sur l'image est la partie à faible performance et à longue consommation de temps. Nous pouvons optimiser le code système en fonction des fonctions marquées en rouge

De plus, la signification du. Champs du rapport xhprof :

Nom de la fonction : Nom de la méthode.

Appels : Le nombre de fois que la méthode a été appelée.

Calls% : le nombre d'appels de méthode en pourcentage du nombre total d'appels de méthode au même niveau.

Incl.Wall Time (microsec) : Le temps nécessaire à l'exécution de la méthode, y compris le temps d'exécution des sous-méthodes. (Unité : microsecondes)

IWall% : Le pourcentage de temps passé à l'exécution de la méthode.

Excl. Wall Time (microsec) : Le temps nécessaire pour exécuter la méthode elle-même, à l'exclusion du temps d'exécution des sous-méthodes. (Unité : microsecondes)

EWall% : Le pourcentage de temps passé à exécuter la méthode elle-même.

Incl. CPU (microsecs) : temps CPU consacré à l'exécution de la méthode, y compris le temps d'exécution des sous-méthodes. (Unité : microsecondes)

ICpu% : Le pourcentage de temps CPU consacré à l'exécution de la méthode.

Excl. CPU (microsec) : Le temps CPU passé à exécuter la méthode elle-même, à l'exclusion du temps d'exécution des sous-méthodes. (Unité : microsecondes)

ECPU% : Le pourcentage de temps CPU passé à exécuter la méthode elle-même.

Incl.MemUse(bytes) : La mémoire occupée par l'exécution de la méthode, y compris la mémoire occupée par l'exécution de la sous-méthode. (Unité : octets)

IMemUse% : Le pourcentage de mémoire occupé par l'exécution de la méthode.

Excl.MemUse(bytes) : La mémoire occupée par l'exécution de la méthode elle-même, à l'exclusion de la mémoire occupée par l'exécution des sous-méthodes. (Unité : Octets)

EMemUse% : Le pourcentage de mémoire occupé par l'exécution de la méthode elle-même.

Incl.PeakMemUse (octets) : Incl.MemUse valeur de crête. (Unité : octets)

IPeakMemUse% : Incl.MemUse pourcentage de pointe.

Excl.PeakMemUse (octets) : valeur de crête Excl.MemUse. Unité : (octet)

EPeakMemUse% : Excl.MemUse pourcentage de pointe.

Recommandations associées :

Analyse et solutions des goulots d'étranglement des performances de démarrage JavaScript

Utilisez xdebug pour analyser les programmes php et découvrir les Goulots d'étranglement des performances

Suivez les goulots d'étranglement des performances du code PHP

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal