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!