Глядя на файл конфигурации Apache, я вижу, что определены Prefork и Worker MPM. В чем разница и какой из них использует Apache?
114
Prefork и worker - это два типа MPM apache. У обоих есть свои достоинства и недостатки.
По умолчанию mpm - это prefork, который является потокобезопасным.
Prefork MPM использует несколько дочерних процессов с одним потоком каждый, и каждый процесс обрабатывает одно соединение за раз.
Worker MPM использует несколько дочерних процессов с множеством потоков в каждом. Каждый поток обрабатывает одно соединение за раз.
Для получения дополнительных сведений посетите https://httpd.apache.org/docs/2.4/mpm.html и https://httpd.apache.org/docs/2.4/mod/prefork.html.
Модули многопроцессорной обработки (MPM) Apache отвечают за привязку к сетевым портам на машине, прием запросов и отправку дочерних элементов для обработки запросов ( http://httpd.apache.org/docs/2.2/mpm.html ).
Они похожи на любой другой модуль Apache, за исключением того, что только один и только один MPM должен быть загружен на сервер в любое время . MPM выбираются во время настройки и компилируются в сервер с помощью аргумента
--with-mpm=NAME
скрипта настройки, гдеNAME
- имя желаемого MPM.Apache будет использовать MPM по умолчанию для каждой операционной системы, если во время компиляции не будет выбрана другая (например, в Windows
mpm_winnt
по умолчанию используется). Вот список операционных систем и их MPM по умолчанию:beos
mpm_netware
mpmt_os2
prefork
( обновление для версии Apache ≥ 2.4 :prefork
,worker
илиevent
, в зависимости от возможностей платформы)mpm_winnt
Чтобы проверить, какие модули скомпилированы на сервере, используйте параметр командной строки
-l
( вот документация). Например, при установке Windows вы можете получить что-то вроде:Начиная с версии 2.2 это список доступных основных функций и модулей MPM :
core
- Основные функции HTTP-сервера Apache, которые всегда доступныmpm_common
- Набор директив, которые реализуются более чем одним модулем многопроцессорной обработки (MPM)beos
- Этот модуль многопроцессорности оптимизирован для BeOS.event
- Опытный вариант штатного рабочего МПМmpm_netware
Модуль многопроцессорности, реализующий исключительно многопоточный веб-сервер, оптимизированный для Novell NetWarempmt_os2
Гибридный многопроцессорный, многопоточный MPM для OS / 2prefork
Реализует непоточный веб-сервер с предварительным форкомmpm_winnt
- Этот модуль мультиобработки оптимизирован для Windows NT.worker
- Модуль Multi-Processing, реализующий гибридный многопоточный многопроцессорный веб-серверТеперь о разнице между
prefork
иworker
.prefork
MPMВ
worker
MPM реализует гибридную многозадачность многопоточного сервер и дает более высокой производительность, поэтому оно должно быть предпочтительным , если один не используют другие модули , которые содержат не-поточно-библиотеку (см также дискуссию или это на Serverfault).источник
Взгляните на это для получения более подробной информации. Это относится к тому, как Apache обрабатывает несколько запросов. Предварительная подготовка, которая используется по умолчанию, запускает несколько процессов Apache (здесь по умолчанию 2, хотя я считаю, что это можно настроить через httpd.conf). Рабочий MPM будет запускать новый поток для каждого запроса, что, как я предполагаю, более эффективно с точки зрения памяти. Исторически сложилось так, что Apache использовал prefork, поэтому это лучше протестированная модель. Потоки были добавлены только в 2.0.
источник
Для CentOS 6.x и 7.x (включая Amazon Linux) используйте:
Это покажет вам, какие из MPM настроены. Либо prefork, worker, либо событие. Prefork - это более ранняя поточно-ориентированная модель. Worker является многопоточным, а событие поддерживает php-mpm, который должен быть лучшей системой для обработки потоков и запросов.
Однако ваши результаты могут отличаться в зависимости от конфигурации. Я видел много нестабильности в php-mpm и никаких улучшений скорости. Агрессивный паук довольно легко может исчерпать максимум дочерних процессов в php-mpm.
Настройка для prefork, worker или event устанавливается в sudo nano /etc/httpd/conf.modules.d/00-mpm.conf (для CentOS 6.x / 7.x / Apache 2.4).
источник
Вы можете определить, использует ли Apache преформу или worker, выполнив следующую команду
В полученном результате ищите упоминания prefork.c или worker.c
источник
apachectl -V
посмотреть на вывод рядом сServer MPM
. Также можете проверитьps aux
и найти либоhttpd
илиhttpd.worker
.apache2ctl -l
не сработало; пришлось использоватьapachectl -l
.httpd -V
Server MPM: worker
Легко переключаться между prefork и worker mpm в Apache 2.4 на RHEL7
Проверьте тип MPM, выполнив
Теперь, чтобы изменить MPM, отредактируйте следующий файл и раскомментируйте требуемый MPM
источник
В Apache определены 2 типа MPM (Multi-Processing Modules):
1: Prefork 2: Worker
По умолчанию Apacke настроен в предварительно форкованном режиме, то есть в непоточном предварительном форковом веб-сервере. Это означает, что каждый дочерний процесс Apache содержит один поток и обрабатывает по одному запросу за раз. Из-за этого потребляется больше ресурсов.
В Apache также есть рабочий MPM, который превращает Apache в многопроцессорный многопоточный веб-сервер. Worker MPM использует несколько дочерних процессов с множеством потоков в каждом.
источник