Ответы:
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 вы можете получить что-то вроде:
> httpd -l
Compiled in modules:
core.c
mod_win32.c
mpm_winnt.c
http_core.c
mod_so.c
Начиная с версии 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
.
реализует непоточный веб-сервер с предварительным форком, который обрабатывает запросы аналогично Apache 1.3. Это подходит для сайтов, которым необходимо избегать потоковой передачи для совместимости с небезопасными библиотеками. Это также лучший MPM для изоляции каждого запроса, так что проблема с одним запросом не повлияет на другие.
В worker
MPM реализует гибридную многозадачность многопоточного сервер и дает более высокой производительность, поэтому оно должно быть предпочтительным , если один не используют другие модули , которые содержат не-поточно-библиотеку (см также дискуссию или это на Serverfault).
Взгляните на это для получения более подробной информации. Это относится к тому, как Apache обрабатывает несколько запросов. Предварительная подготовка, которая используется по умолчанию, запускает несколько процессов Apache (здесь по умолчанию 2, хотя я считаю, что это можно настроить через httpd.conf). Рабочий MPM будет запускать новый поток для каждого запроса, что, как я предполагаю, более эффективно с точки зрения памяти. Исторически сложилось так, что Apache использовал prefork, поэтому это лучше протестированная модель. Потоки были добавлены только в 2.0.
Для CentOS 6.x и 7.x (включая Amazon Linux) используйте:
sudo httpd -V
Это покажет вам, какие из 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).
# Select the MPM module which should be used by uncommenting exactly
# one of the following LoadModule lines:
# prefork MPM: Implements a non-threaded, pre-forking web server
# See: http://httpd.apache.org/docs/2.4/mod/prefork.html
#LoadModule mpm_prefork_module modules/mod_mpm_prefork.so
# worker MPM: Multi-Processing Module implementing a hybrid
# multi-threaded multi-process web server
# See: http://httpd.apache.org/docs/2.4/mod/worker.html
#LoadModule mpm_worker_module modules/mod_mpm_worker.so
# event MPM: A variant of the worker MPM with the goal of consuming
# threads only for connections with active processing
# See: http://httpd.apache.org/docs/2.4/mod/event.html
#LoadModule mpm_event_module modules/mod_mpm_event.so
Вы можете определить, использует ли Apache преформу или worker, выполнив следующую команду
apache2ctl -l
В полученном результате ищите упоминания 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, выполнив
sudo httpd -V
Server version: Apache/2.4.6 (Red Hat Enterprise Linux)
Server built: Jul 26 2017 04:45:44
Server's Module Magic Number: 20120211:24
Server loaded: APR 1.4.8, APR-UTIL 1.5.2
Compiled using: APR 1.4.8, APR-UTIL 1.5.2
Architecture: 64-bit
Server MPM: prefork
threaded: no
forked: yes (variable process count)
Server compiled with....
-D APR_HAS_SENDFILE
-D APR_HAS_MMAP
-D APR_HAVE_IPV6 (IPv4-mapped addresses enabled)
-D APR_USE_SYSVSEM_SERIALIZE
-D APR_USE_PTHREAD_SERIALIZE
-D SINGLE_LISTEN_UNSERIALIZED_ACCEPT
-D APR_HAS_OTHER_CHILD
-D AP_HAVE_RELIABLE_PIPED_LOGS
-D DYNAMIC_MODULE_LIMIT=256
-D HTTPD_ROOT="/etc/httpd"
-D SUEXEC_BIN="/usr/sbin/suexec"
-D DEFAULT_PIDLOG="/run/httpd/httpd.pid"
-D DEFAULT_SCOREBOARD="logs/apache_runtime_status"
-D DEFAULT_ERRORLOG="logs/error_log"
-D AP_TYPES_CONFIG_FILE="conf/mime.types"
-D SERVER_CONFIG_FILE="conf/httpd.conf"
Теперь, чтобы изменить MPM, отредактируйте следующий файл и раскомментируйте требуемый MPM
/etc/httpd/conf.modules.d/00-mpm.conf
# Select the MPM module which should be used by uncommenting exactly
# one of the following LoadModule lines:
# prefork MPM: Implements a non-threaded, pre-forking web server
# See: http://httpd.apache.org/docs/2.4/mod/prefork.html
LoadModule mpm_prefork_module modules/mod_mpm_prefork.so
# worker MPM: Multi-Processing Module implementing a hybrid
# multi-threaded multi-process web server
# See: http://httpd.apache.org/docs/2.4/mod/worker.html
#
#LoadModule mpm_worker_module modules/mod_mpm_worker.so
# event MPM: A variant of the worker MPM with the goal of consuming
# threads only for connections with active processing
# See: http://httpd.apache.org/docs/2.4/mod/event.html
#
#LoadModule mpm_event_module modules/mod_mpm_event.so
В Apache определены 2 типа MPM (Multi-Processing Modules):
1: Prefork 2: Worker
По умолчанию Apacke настроен в предварительно форкованном режиме, то есть в непоточном предварительном форковом веб-сервере. Это означает, что каждый дочерний процесс Apache содержит один поток и обрабатывает по одному запросу за раз. Из-за этого потребляется больше ресурсов.
В Apache также есть рабочий MPM, который превращает Apache в многопроцессорный многопоточный веб-сервер. Worker MPM использует несколько дочерних процессов с множеством потоков в каждом.