


Exemple d'explication de l'utilisation de XHProf pour rechercher les goulots d'étranglement des performances PHP
L'éditeur suivant 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 sera utile à tout le monde. Suivons l’éditeur et jetons un coup d’œil
1. Installez 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
2. Modifier php.ini
[xhprof] extension=xhprof.so xhprof.output_dir=/tmp
Dans la configuration, xhprof.output_dir précise l'emplacement où se trouve le fichier de profil généré stocké. Nous le ferons Il est désigné par /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/
Configurer un domaine nom , le navigateur peut 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; } }
4. Installez graphivz
//需要安装graphviz否则查看性能图片时候会报failed to execute cmd: " dot -Tpng". stderr: `sh: dot: command not found ' yum -y install graphviz
5. Écrivez 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");
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]['min']*10000, $rules[$index]['max']*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,最后我们输出了一个链接地址,使用改地址就可以看到本次请求的分析结果。
6. Consultez les résultats de l'analyse
Exécutez d'abord le code commercial
Ensuite, le navigateur s'ouvre http://will.com/xhprof/xhprof_html/index ; .php, cliquez une dernière fois pour générer le fichier xhprof
et remarquez le <span style="font-family:NSimsun">View Full Lien Callgraph<code><span style="font-family:NSimsun">View Full Callgraph</span>
, à travers lequel nous pouvons voir les résultats de l'analyse graphique
La partie rouge dans l'image indique des performances inférieures et une perte de temps comparaison Pour la partie longue, nous pouvons optimiser le code du système en fonction des fonctions marquées en rouge
De plus, le champ de rapport xhprof signifie :
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) : Le 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% : pourcentage de pic Excl.MemUse.
L'exemple ci-dessus d'utilisation de XHProf pour trouver les goulots d'étranglement des performances PHP est tout le contenu partagé par l'éditeur. J'espère qu'il pourra vous donner une référence, et j'espère que vous soutiendrez le site Web php chinois.
Articles qui pourraient vous intéresser :
Résumé connexe des directives de modèles personnalisés dans le framework Laravel
Un exemple de la façon d'implémenter un tri rapide à l'aide de PHP de manière récursive
Un tutoriel détaillé sur la façon d'implémenter le déploiement de git à l'aide de 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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

PHP 8.4 apporte plusieurs nouvelles fonctionnalités, améliorations de sécurité et de performances avec une bonne quantité de dépréciations et de suppressions de fonctionnalités. Ce guide explique comment installer PHP 8.4 ou mettre à niveau vers PHP 8.4 sur Ubuntu, Debian ou leurs dérivés. Bien qu'il soit possible de compiler PHP à partir des sources, son installation à partir d'un référentiel APT comme expliqué ci-dessous est souvent plus rapide et plus sécurisée car ces référentiels fourniront les dernières corrections de bogues et mises à jour de sécurité à l'avenir.

CakePHP est un framework open source pour PHP. Il vise à faciliter grandement le développement, le déploiement et la maintenance d'applications. CakePHP est basé sur une architecture de type MVC à la fois puissante et facile à appréhender. Modèles, vues et contrôleurs gu

Pour travailler sur le téléchargement de fichiers, nous allons utiliser l'assistant de formulaire. Voici un exemple de téléchargement de fichiers.

Visual Studio Code, également connu sous le nom de VS Code, est un éditeur de code source gratuit – ou environnement de développement intégré (IDE) – disponible pour tous les principaux systèmes d'exploitation. Avec une large collection d'extensions pour de nombreux langages de programmation, VS Code peut être c

CakePHP est un framework MVC open source. Cela facilite grandement le développement, le déploiement et la maintenance des applications. CakePHP dispose d'un certain nombre de bibliothèques pour réduire la surcharge des tâches les plus courantes.

Ce tutoriel montre comment traiter efficacement les documents XML à l'aide de PHP. XML (Language de balisage extensible) est un langage de balisage basé sur le texte polyvalent conçu à la fois pour la lisibilité humaine et l'analyse de la machine. Il est couramment utilisé pour le stockage de données et

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

Une chaîne est une séquence de caractères, y compris des lettres, des nombres et des symboles. Ce tutoriel apprendra à calculer le nombre de voyelles dans une chaîne donnée en PHP en utilisant différentes méthodes. Les voyelles en anglais sont a, e, i, o, u, et elles peuvent être en majuscules ou en minuscules. Qu'est-ce qu'une voyelle? Les voyelles sont des caractères alphabétiques qui représentent une prononciation spécifique. Il y a cinq voyelles en anglais, y compris les majuscules et les minuscules: a, e, i, o, u Exemple 1 Entrée: String = "TutorialSpoint" Sortie: 6 expliquer Les voyelles dans la chaîne "TutorialSpoint" sont u, o, i, a, o, i. Il y a 6 yuans au total
