pet*_*nar 12 php performance apache2 mod-php nginx
我一直在寻找好几天,看看有没有人做过良好的,有文档记录的,PHP处理速度之间的比较
和
为什么我要看:我看到的唯一测试是基准测试,提供完整页面或Hello,类似世界的测试,没有关于测试内容的正确文档.我不关心请求/秒,硬件,但我确实需要看看测试了什么PHP脚本以及具体配置.
为什么这两个: mod_php被认为是处理PHP最快的(没有静态文件,没有请求/响应测量,只是处理PHP本身)但是从那以后发生了很多变化,包括apache版本.nginx的和PHP-FPM吃得少了很多的内存,所以这会是一个很好的理由来改变架构,但如果他们不够快在这种情况下,变化是不相关的.
我知道如果我找不到一个我必须自己做,但我不敢相信没有人做过这样的测试到目前为止:)
sjd*_*aws 13
我已经完成了在CentOS 6.3本次测试使用nginx 1.2.7,apache 2.4.3并且php 5.4.12所有在不改变默认编译.
./configure
make && make install
Run Code Online (Sandbox Code Playgroud)
除了php,我启用了php-fpm
./configure --enable-fpm
Run Code Online (Sandbox Code Playgroud)
除非如下所述,否则所有服务器都具有100%默认配置.所有测试都在测试服务器上完成,没有负载,测试之间重新启动.该服务器在RAID 1中具有Intel(R)Xeon(R)CPU E3-1230,1GB RAM和2 x 60GB SSD.测试使用ab -n 50000 -c 500 http://127.0.0.1/test.php
测试PHP脚本:
<?php
$testing = 0;
for ($i = 0; $i < 1000; $i++) {
$testing++;
}
echo $testing;
Run Code Online (Sandbox Code Playgroud)
我还必须启用php,nginx.conf因为默认情况下它没有启用.
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /var/www/html$fastcgi_script_name;
include fastcgi_params;
}
Run Code Online (Sandbox Code Playgroud)
Nginx - PHP-FPM在127.0.0.1:9000
Concurrency Level: 500
Time taken for tests: 10.932 seconds
Complete requests: 50000
Failed requests: 336
(Connect: 0, Receive: 0, Length: 336, Exceptions: 0)
Write errors: 0
Non-2xx responses: 336
Total transferred: 7837824 bytes
HTML transferred: 379088 bytes
Requests per second: 4573.83 [#/sec] (mean)
Time per request: 109.317 [ms] (mean)
Time per request: 0.219 [ms] (mean, across all concurrent requests)
Transfer rate: 700.17 [Kbytes/sec] received
Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 34 338.5 0 7000
Processing: 0 34 166.5 23 8120
Waiting: 0 34 166.5 23 8120
Total: 13 68 409.2 23 9846
Percentage of the requests served within a certain time (ms)
50% 23
66% 28
75% 32
80% 33
90% 34
95% 46
98% 61
99% 1030
100% 9846 (longest request)
Run Code Online (Sandbox Code Playgroud)
Nginx - 通过套接字的PHP-FPM(配置更改为fastcgi_pass)
fastcgi_pass unix:/var/lib/php/php.sock;
Concurrency Level: 500
Time taken for tests: 7.054 seconds
Complete requests: 50000
Failed requests: 351
(Connect: 0, Receive: 0, Length: 351, Exceptions: 0)
Write errors: 0
Non-2xx responses: 351
Total transferred: 7846209 bytes
HTML transferred: 387083 bytes
Requests per second: 7087.70 [#/sec] (mean)
Time per request: 70.545 [ms] (mean)
Time per request: 0.141 [ms] (mean, across all concurrent requests)
Transfer rate: 1086.16 [Kbytes/sec] received
Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 26 252.5 0 7001
Processing: 0 24 112.9 17 3683
Waiting: 0 24 112.9 17 3683
Total: 7 50 306.4 17 7001
Percentage of the requests served within a certain time (ms)
50% 17
66% 19
75% 20
80% 21
90% 23
95% 31
98% 55
99% 1019
100% 7001 (longest request)
Run Code Online (Sandbox Code Playgroud)
Apache - mod_php
Concurrency Level: 500
Time taken for tests: 10.979 seconds
Complete requests: 50000
Failed requests: 0
Write errors: 0
Total transferred: 9800000 bytes
HTML transferred: 200000 bytes
Requests per second: 4554.02 [#/sec] (mean)
Time per request: 109.793 [ms] (mean)
Time per request: 0.220 [ms] (mean, across all concurrent requests)
Transfer rate: 871.67 [Kbytes/sec] received
Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 22 230.2 1 7006
Processing: 0 58 426.0 18 9612
Waiting: 0 58 425.9 18 9611
Total: 5 80 523.8 19 10613
Percentage of the requests served within a certain time (ms)
50% 19
66% 23
75% 25
80% 26
90% 31
95% 36
98% 1012
99% 1889
100% 10613 (longest request)
Run Code Online (Sandbox Code Playgroud)
我会非常乐意进一步调整apache,但似乎apache无法跟上.明显的赢家是nginx与php-fpm通过套接字.
| 归档时间: |
|
| 查看次数: |
9358 次 |
| 最近记录: |