Maison  >  Article  >  développement back-end  >  Gdb débogage php trouve facilement le code en cours d'exécution

Gdb débogage php trouve facilement le code en cours d'exécution

little bottle
little bottleavant
2019-04-25 17:52:044292parcourir

Supposons qu'il y ait un script php en ligne et que quelque chose se passe soudainement un jour. Il n'est pas géré mais le processus ne se termine pas. Cette situation peut être due à un sommeil anormal ou à une boucle de code sans fin, mais comment la localiser ? Ce que nous voulons le plus savoir à ce moment-là devrait être ce que fait ce script à ce moment-là. Ceci est utile si gdb+zbacktrace est utilisé.

Tout d'abord, écrivez un script de test test.php et écrivez-y une fonction sleep. Vous pouvez également le changer en boucle infinie.

<?phpfunction Mecho($i){ echo $i.PHP_EOL;
}$i = 20;while($i>0){if($i%2==0){
  Mecho($i);
}sleep(100000);$i--;
}

zbacktrace est inclus dans le package de code source php téléchargé Mon environnement vient d'être installé et la version actuelle de php est php7.2.9

Cli direct pour exécuter test.php

php test.php

Ensuite, recherchez le processus php actuel

 

Ensuite, utilisez gdb pour déboguer

gdb -p 56571

Déboguer

source /usr/local/src/php-7.2.9/.gdbinit
zbacktrace

À l'heure actuelle, nous savons que le processus sleep est provoqué par la fonction sleep de la ligne 11 de test.php.

Tutoriels associés : Tutoriel vidéo 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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer
Article précédent:Analyse régulière PHP PCREArticle suivant:Analyse régulière PHP PCRE