这个问题与我之前的问题(在这里)有关。
起初我认为这是一个网络问题,但越来越可能是与我的php配置和php文件的运行有关。我进行了以下测试:
我创建了一个名为
对我来说,似乎无论我尝试运行哪个PHP脚本,其运行时间都至少增加了半秒钟。我无法解决这个问题,因此非常感谢任何帮助!
编辑1:我制作了一个简单的脚本,我希望这就是@Eineki所说的内部测试。该脚本如下:
以下是结果:
起初我认为这是一个网络问题,但越来越可能是与我的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'命令来预处理,例如: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
// 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
对我来说,似乎无论我尝试运行哪个PHP脚本,其运行时间都至少增加了半秒钟。我无法解决这个问题,因此非常感谢任何帮助!
编辑1:我制作了一个简单的脚本,我希望这就是@Eineki所说的内部测试。该脚本如下:
$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";
以下是结果:
测试结果如下:
所需测试持续时间为:0.00102400779724秒
执行测试持续时间为:0.61318397522秒
编辑2:已加载的扩展列表如下:
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版本,使用命令php -v
查看:
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
编辑 3: 如@voter所建议的那样,在生产服务器(即问题服务器)和我们的开发服务器上运行strace
,在这个问题不会发生的开发服务器上。 strace
输出的所有内容在生产服务器上基本上是开发服务器上的10倍。也许熟悉strace
的人可以从中得出结论?
编辑 4:
vmstat 1
命令的摘录:
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
编辑5:
服务器上top
命令的结果:
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
/usr/bin/php /testFirstByte/test.php
是 CLI,而不是 Apache。 - brombeerphp -v
显示"with Zend OPcache...",也许你的PHP缺少OPcache(不知道是否可能,瞎猜的)。祝好运。 - brombeeropcache
吗?opcache.enable_cli=1
- Diogo Sgrillo