Ноль простаивающих рабочих на сервере apache2, вызывающих проблемы с производительностью

У меня есть продукт 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
задан 25 August 2020 в 14:02
2 ответа

С предварительным форком MPM, если вы увеличиваете MaxRequestWorkers , вам также необходимо поднять ServerLimit .

Для серверов без потоковой передачи (т. Е. Предварительный форк) , MaxRequestWorkers преобразуется в максимальное количество дочерних процессов, которые будут запущены для обслуживания запросов. Значение по умолчанию - 256; чтобы увеличить его, необходимо также увеличить ServerLimit.

https://httpd.apache.org/docs/2.4/mod/mpm_common.html#maxrequestworkers

2
ответ дан 4 January 2021 в 08:35

С mpm_prefork, веб-сервер порождает новые процессы для обработки запросов. Каждый процесс может обрабатывать только один запрос за раз.

В вашем примере ваш веб-сервер настроен так, чтобы иметь минимум 5 незанятых серверных процессов, ожидающих обработки запросов, и максимум 10. Учитывая, что вы обрабатываете более 250 одновременных запросов, возможно, ваш веб-сервер не может достаточно быстро запускать новые процессы.

Я бы увеличил значения StartServers, MinSpareServers и MaxSpareServers, чтобы обеспечить достаточную доступную емкость для пиков нагрузки или больших нагрузок.

Вы также можете рассмотреть возможность перехода на другой модуль многопроцессорной обработки в зависимости от типа рабочей нагрузки, которую вам нужно обслуживать.

Изменить: ответ @tetech является правильным, однако вы также можете рассмотреть возможность настройки этих значений, поскольку это может повысить производительность веб-сервера.

0
ответ дан 4 January 2021 в 08:35

Теги

Похожие вопросы