Скорость обработки PHP в Апач 2.4 и MPM-prefork в мод версии PHP 5.4 nginx в против 1.2.X PHP-FPM 5.4
Я искал дни, чтобы увидеть, сделал ли кто-то хорошее, документированное сравнение скорости обработки PHP между
- apache-mpm-prefork 2.4 с mod_php 5.4
и
- nginx 1.2.x + PHP-FPM 5.4
почему я ищу: единственный тест, который я видел, - это тесты, обслуживающие полные страницы или Hello, World-like test, без надлежащей документации о том, что именно было протестировано. Меня не волнует о запросе / секундах, аппаратном обеспечении, но мне нужно посмотреть, какой PHP-скрипт был протестирован и с какой точной конфигурацией.
почему эти два: mod_php был известен как самый быстрый в обработке PHP (без статических файлов, без измерения запросов/ответов, просто обработка самого PHP), но с тех пор многое изменилось, включая версию apache. Nginx и PHP-FPM потребляют намного меньше памяти, поэтому было бы неплохо изменить архитектуру, но если они недостаточно быстры в в этом случае изменения не будут иметь значения.
Я знаю, если я не могу найти его, я должен сделать это сам, но я не могу поверить, что никто не сделал такой тест до сих пор:)
2 ответов
я завершил этот тест на CentOS 6.3, используя nginx 1.2.7
, apache 2.4.3
и php 5.4.12
все компилируется без изменения.
./configure
make && make install
за исключением php, где я включил php-fpm
./configure --enable-fpm
все серверы имеют конфигурацию по умолчанию 100%, за исключением случаев, указанных ниже. Все тестирование проводилось на тестовом сервере без нагрузки и перезагрузки между тестами. Сервер имеет Intel(R) Xeon (R) CPU E3-1230, 1GB RAM и 2 x 60GB SSD в RAID 1. Тесты были выполнены с использованием 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;
мне также пришлось включить 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;
}
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)
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)
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)
я буду более чем счастлив настроить apache дальше, но, похоже, apache просто не может идти в ногу. Явный победитель-nginx с php-fpm через гнездо.
кажется, вы сравниваете яблоки с апельсинами, или, точнее говоря, вы путаете результаты, регулируя две переменные. Конечно, было бы разумнее сравнить Apache+fastcgi+php-fpm с nginx+php-fpm? Вы ожидаете, что часть php-fpm будет такой же, поэтому вы будете измерять лучшее из Apache_fastcgi против nginx.