在服务器上执行php脚本非常慢

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

这个问题与我的另一个问题found here有关。

起初我认为这是一个网络问题,但似乎越来越可能,这与我的php配置和php文件的运行有关。我做了以下测试用例:

我创建了一个名为test.php的php文件,其中包含以下内容:

 <?php
 echo 'test';
 ?>

并创建了两个bash文件,其中包含以下内容:

//bash1.sh
#!/bin/bash
/usr/bin/php /testFirstByte/test.php

和另一个

//bash2.sh
#!/bin/bash
echo Test;

然后我继续他们的运行时间,运行每个并在其前面加上'time'命令,是:qazxsw poi

结果如下:

time php test.php

 // time php test.php
 test
 real    0m0.548s
 user    0m0.445s
 sys     0m0.101s

 // time sh bash2.hs
 Test
 real    0m0.002s
 user    0m0.002s
 sys     0m0.000s

对我来说,看起来,每当我尝试运行PHP脚本时,运行时间会增加至少半秒,无论我尝试运行哪个PHP脚本。我无法弄清楚如何解决这个问题,所以任何帮助都会有很大的帮助!

编辑1:我做了一个简单的脚本,我希望这是你的内部测试@Eineki的意思。脚本如下:

 // time sh bash1.hs
 X-Powered-By: PHP/5.5.30
 Content-type: text/html; charset=utf-8
 test
 real    0m0.539s
 user    0m0.429s
 sys     0m0.108s

结果如下:

要求测试持续时间为:0.00102400779724秒 Exec测试持续时间为:0.61318397522秒

编辑2:加载的扩展名列表如下:

$timer = microtime(true);
require('test_simple.php');
$end = microtime(true) - $timer;
echo "Require test duration was: " . $end . " seconds\n";

$timer = microtime(true);
exec('php test_simple.php');
$end = microtime(true) - $timer;
echo "Exec test duration was: " . $end . " seconds\n";

这是我的PHP版本,从Array ( [0] => Core [1] => date [2] => ereg [3] => libxml [4] => openssl [5] => pcre [6] => sqlite3 [7] => zlib [8] => bcmath [9] => bz2 [10] => calendar [11] => ctype [12] => curl [13] => dom [14] => hash [15] => fileinfo [16] => filter [17] => ftp [18] => gd [19] => gettext [20] => SPL [21] => iconv [22] => session [23] => json [24] => mbstring [25] => mcrypt [26] => standard [27] => mysql [28] => mysqli [29] => mysqlnd [30] => Phar [31] => posix [32] => Reflection [33] => imap [34] => SimpleXML [35] => sockets [36] => exif [37] => tokenizer [38] => xml [39] => xmlreader [40] => xmlwriter [41] => zip [42] => cgi-fcgi [43] => PDO [44] => pdo_sqlite [45] => pdo_mysql [46] => mailparse [47] => Zend OPcache )

php -v

编辑3:按照@voter在php文件上的建议运行PHP 5.5.30 (cgi-fcgi) (built: Dec 3 2015 06:55:27) Copyright (c) 1997-2015 The PHP Group Zend Engine v2.5.0, Copyright (c) 1998-2015 Zend Technologies with Zend OPcache v7.0.4-dev, Copyright (c) 1999-2014, by Zend Technologies ,无论是在生产服务器(有问题的服务器)上,还是在我们的开发服务器上,都不会出现此问题。 strace输出的所有东西在prod服务器上基本上是10倍,然后在开发服务器上。也许熟悉strace的人可以从中得出结论?

编辑4:

摘自strace命令:

vmstat 1

编辑5:

服务器上的procs -----------memory---------- ---swap-- -----io---- --system-- -----cpu----- r b swpd free buff cache si so bi bo in cs us sy id wa st 5 0 3163644 5410932 2522564 13417292 0 1 22 62 1 0 18 6 75 1 0 2 0 3163644 5845884 2522568 13406468 0 0 0 916 31787 5966 9 6 85 0 0 8 0 3163644 5439468 2522572 13406840 0 0 8 432 50513 5322 12 6 82 0 0 4 0 3163644 5750124 2522572 13407624 0 0 4 232 54417 5615 8 7 86 0 0 4 0 3163644 5748608 2522576 13407480 0 0 4 760 118206 5736 7 9 83 0 0 3 0 3163644 5742648 2522576 13418040 0 0 0 244 68462 6689 10 7 83 0 0 4 0 3163644 5671104 2522576 13407620 0 0 40 568 34157 4222 7 5 87 0 0 4 0 3163644 5980828 2522580 13401712 0 0 16 524 43754 6391 17 6 77 0 0 5 0 3163644 5506988 2522592 13418868 0 0 264 280 59452 5955 16 7 77 0 0 5 0 3163644 5577116 2522600 13417800 0 0 32 540 68056 8968 11 6 83 0 0 7 0 3163644 4747580 2522612 13451468 0 0 16 376 241800 7107 12 13 75 0 0 4 0 3163644 4948548 2522616 13440832 0 0 12 468 354599 5155 7 16 77 0 0 命令的结果:

top
php benchmarking
3个回答
3
投票

您的top - 09:17:58 up 15 days, 1:53, 8 users, load average: 6.90, 6.22, 5.34 Tasks: 687 total, 3 running, 683 sleeping, 0 stopped, 1 zombie Cpu(s): 15.0%us, 3.4%sy, 0.0%ni, 80.7%id, 0.8%wa, 0.0%hi, 0.1%si, 0.0%st Mem: 49390000k total, 43364688k used, 6025312k free, 2697344k buffers Swap: 16482300k total, 3495772k used, 12986528k free, 11878096k cached 输出看起来像是从命令行调用php cgi。

对于命令行,通常有一个php版本的php,它可以单独安装,例如php -v

这会对性能产生很大影响。对中型Linux服务器的快速测试给了我

apt-get install php5-cli

如您所见,cgi版本的时间加倍。您是否可以尝试使用CLI版本来查看差异是否仍然很大?

这可能无法帮助您解决您提到的其他线程中的问题,除非您还在那里使用CGI模块并且没有正确配置它。


2
投票

最后找到导致问题的原因:它是扩展之一,即#time php-cgi test.php X-Powered-By: PHP/5.5.26 Content-type: text/html test real    0m0.117s user    0m0.036s sys     0m0.076s # time php test.php test real    0m0.074s user    0m0.040s sys     0m0.036s 扩展,或更可能是缺乏它。

在某些时候,它已经安装,但是当我们意识到,我们不会使用它,出于不同的原因,我们卸载它,但它没有从browsecap文件中删除。通过从ini文件中删除与php.ini相关的单行,问题完全解决了。

我要感谢@Pampy指出我正确的方向,扩展。如果有人在将来经历类似的事情,如果问题是相似的话,调试的一个选项是从命令行运行php,使用browsecap参数,它实际上禁用了它的ini,以及所有加载的扩展。


0
投票

对我来说这很好。

-n

尝试一下,我想在你的配置上看到结果。由于它是命令行触发,我怀疑你不需要输出。您可以将输入作为参数发送。

© www.soinside.com 2019 - 2024. All rights reserved.