如何衡量PHP性能?

问题描述 投票:0回答:4

如何对 PHP 中的某些代码段进行基准测试?我可以使用计时器来计算差异,但我只是不确定这是否是最好的解决方案。

php performance benchmarking
4个回答
8
投票

查看 XDebug Profiler 以对性能进行基准测试等。

Xdebug 的 Profiler 是一个强大的工具 这使您能够分析 你的 PHP 代码并确定 瓶颈或一般看看哪个 您的部分代码速度很慢并且可能 使用速度提升。


4
投票

您可以使用 profiler,就像 Xdebug 中内置的那样。


1
投票

XDebug 很酷,但如果你不想安装这个库,你可以尝试以下操作:

我用来定位可能的瓶颈的是:

$benchmark_start = microtime(true);
// Code goes here
$benchmark_stop = microtime(true);
$benchmark_total = $benchmark_stop - $benchmark_start;
echo "The script took ". $benchmark_total." seconds";

0
投票

使用计时器进行手动分析的更复杂的示例
对我来说非常适合,特别是当我被要求在一些仅具有 FTP 访问权限的实时服务器上解决问题时。
不用说,分析在实时服务器上比在温室开发人员的 PC 上更重要(也更有用)。

$TIMER['start']=microtime(TRUE);
// some code
$query="SELECT ...";
$TIMER['before q']=microtime(TRUE);
  $res=mysql_query($query);
$TIMER['after q']=microtime(TRUE);  
  while ($row = mysql_fetch_array($res)) {
// some code
  }
$TIMER['array filled']=microtime(TRUE);  
// some code
$TIMER['pagination']=microtime(TRUE);  

if ('127.0.0.1' === $_SERVER['REMOTE_ADDR']) { //I set my IP here
  echo "<table border=1><tr><td>name</td><td>so far</td><td>delta</td><td>per cent</td></tr>";
  reset($TIMER);
  $start=$prev=current($TIMER);
  $total=end($TIMER)-$start;
  foreach($TIMER as $name => $value) {
    $sofar=round($value-$start,3);
    $delta=round($value-$prev,3);
    $percent=round($delta/$total*100);
    echo "<tr><td>$name</td><td>$sofar</td><td>$delta</td><td>$percent</td></tr>";
    $prev=$value;
  }
    echo "</table><>";
}
© www.soinside.com 2019 - 2024. All rights reserved.