У меня есть продукт SAAS, созданный на php вместе с apache2 и mysql, и он размещен на AWS. Мое производство очень-очень медленное в часы пик, и когда я проверяю статус сервера, он говорит, что простаивающих рабочих процессов 0 (ноль). Я использую mpm-prefork
Current Time: Monday, 24-Aug-2020 19:36:32 UTC
Restart Time: Friday, 14-Aug-2020 06:03:27 UTC
Parent Server Config. Generation: 12
Parent Server MPM Generation: 11
Server uptime: 10 days 13 hours 33 minutes 5 seconds
Server load: 1.17 1.07 0.95
Total accesses: 28851443 - Total Traffic: 824.8 GB
CPU Usage: u289.99 s50.68 cu0 cs0 - .0373% CPU load
31.6 requests/sec - 0.9 MB/second - 30.0 kB/request
256 requests currently being processed, 0 idle workers
Ниже приведен мой файл настроек mpm-prefork.conf.
<IfModule mpm_prefork_module>
StartServers 5
MinSpareServers 5
MaxSpareServers 10
MaxRequestWorkers 450
MaxConnectionsPerChild 0
</IfModule>
Команда TOP на ubuntu20.04 выдает мне следующее:
top - 20:03:58 up 143 days, 11:16, 1 user, load average: 0.48, 0.71, 0.83
Tasks: 369 total, 3 running, 317 sleeping, 0 stopped, 0 zombie
%Cpu(s): 15.9 us, 3.2 sy, 0.0 ni, 79.9 id, 0.0 wa, 0.0 hi, 1.0 si, 0.0 st
KiB Mem : 7865072 total, 1023492 free, 2752320 used, 4089260 buff/cache
KiB Swap: 0 total, 0 free, 0 used. 4755856 avail Mem
Что касается подробностей, я вижу, что 1 ГБ оперативной памяти все еще свободен. Тогда почему ноль простаивающих рабочих процессов? Кроме того, почему ноль простаивающих рабочих процессов только для 256 запросов, когда я установил MaxRequestWorkers на 450. Максимальный объем оперативной памяти в машине составляет 8 ГБ.
решение1
При использовании предварительной вилки MPM, если вы увеличиваете, MaxRequestWorkers
вам также необходимо поднять ServerLimit
.
Для не потоковых серверов (т. е. prefork) MaxRequestWorkers переводится в максимальное количество дочерних процессов, которые будут запущены для обслуживания запросов. Значение по умолчанию — 256; чтобы увеличить его, необходимо также поднять ServerLimit.
https://httpd.apache.org/docs/2.4/mod/mpm_common.html#maxrequestworkers
решение2
С mpm_prefork веб-сервер порождает новые процессы для обработки запросов. Каждый процесс может обрабатывать только один запрос за раз.
В вашем примере ваш веб-сервер настроен на наличие как минимум 5 бездействующих серверных процессов, ожидающих обработки запросов, и как максимум 10. Учитывая, что вы обрабатываете более 250 одновременных запросов, возможно, ваш веб-сервер не в состоянии достаточно быстро создавать новые процессы.
Я бы увеличил значения StartServers, MinSpareServers и MaxSpareServers, чтобы гарантировать наличие достаточного запаса емкости для пиковых нагрузок или больших нагрузок.
Вы также можете рассмотреть возможность перехода на другой многопроцессорный модуль в зависимости от типа рабочей нагрузки, которую вам необходимо обработать.
Редактировать: ответ @tetech правильный, однако вы также можете рассмотреть возможность настройки этих значений, поскольку это может улучшить производительность веб-сервера.