菜单

九十八个gdb调节和测试技巧

2019年3月3日 - Java

即使线上有一段php脚本,突然在某天出难题了,不处理可是经过没有脱离。这种景观大概是十分休眠或许是有段死循环代码,可是大家怎么固定呢,大家以此时候最想清楚的应当是这几个剧本在那儿在做哪些吧。这么些是gdb+zbacktrace就有用了

找到的1个有参考价值的有关GDB调节和测试的站点:https://gitlore.com/subject/15

先是随便写3个测试脚本test.php,里面就写二个sleep函数,换到死循环也足以。

 

<?php
function Mecho($i){
 echo $i.PHP_EOL;
}
$i = 20;
while($i>0){

if($i%2==0){
  Mecho($i);
}
sleep(100000);
$i--;
}

图片 1

zbacktrace下载php源码包里面就有,当前自家的条件是新装的,当前的php版本是php7.2.9

 

直接cli执行test.php

php test.php

 然后找到当前php进度

   图片 2

 然后用gdb调试

gdb -p 56571

 调试

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

图片 3

 这么些时候就通晓了是在test.php的11行 sleep函数导致的历程sleep。

  

 

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图