Apache Prefork против Worker MPM


114

Глядя на файл конфигурации Apache, я вижу, что определены Prefork и Worker MPM. В чем разница и какой из них использует Apache?

Ответы:


120

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.


11
См. Также «Как выбрать, какой Apache MPM использовать?» serverfault.com/a/383634
Назарий

@arvind // Каждый поток обрабатывает одно соединение за раз // здесь соединение означает одного пользователя или один запрос?
пожалуйста,

21

Модули многопроцессорной обработки (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 по умолчанию:

Чтобы проверить, какие модули скомпилированы на сервере, используйте параметр командной строки -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 NetWare
  • mpmt_os2 Гибридный многопроцессорный, многопоточный MPM для OS / 2
  • prefork Реализует непоточный веб-сервер с предварительным форком
  • mpm_winnt - Этот модуль мультиобработки оптимизирован для Windows NT.
  • worker - Модуль Multi-Processing, реализующий гибридный многопоточный многопроцессорный веб-сервер

Теперь о разнице между preforkи worker.

preforkMPM

реализует непоточный веб-сервер с предварительным форком, который обрабатывает запросы аналогично Apache 1.3. Это подходит для сайтов, которым необходимо избегать потоковой передачи для совместимости с небезопасными библиотеками. Это также лучший MPM для изоляции каждого запроса, так что проблема с одним запросом не повлияет на другие.

В workerMPM реализует гибридную многозадачность многопоточного сервер и дает более высокой производительность, поэтому оно должно быть предпочтительным , если один не используют другие модули , которые содержат не-поточно-библиотеку (см также дискуссию или это на Serverfault).


1
При установке ubuntu-trusty-64 apache 2.4.7 по умолчанию используется событие MPM
Федерико,

9

Взгляните на это для получения более подробной информации. Это относится к тому, как Apache обрабатывает несколько запросов. Предварительная подготовка, которая используется по умолчанию, запускает несколько процессов Apache (здесь по умолчанию 2, хотя я считаю, что это можно настроить через httpd.conf). Рабочий MPM будет запускать новый поток для каждого запроса, что, как я предполагаю, более эффективно с точки зрения памяти. Исторически сложилось так, что Apache использовал prefork, поэтому это лучше протестированная модель. Потоки были добавлены только в 2.0.


3
А как насчет Event MPM?
Винс Кронлайн

6

Для 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

3

Вы можете определить, использует ли Apache преформу или worker, выполнив следующую команду

apache2ctl -l

В полученном результате ищите упоминания prefork.c или worker.c


8
Apache может быть скомпилирован с обоими модулями MPM, поэтому это не всегда надежно. Если в нем перечислены два модуля MPM, попробуйте apachectl -Vпосмотреть на вывод рядом с Server MPM. Также можете проверить ps auxи найти либо httpdили httpd.worker.
reflexiv

2
В моем случае apache2ctl -lне сработало; пришлось использовать apachectl -l.
Vacilando

2
ни один из них не указан для меня, но apache работает нормально, Apache / 2.4.7 (Ubuntu)
karatedog

2
В centos 7.x, на котором запущен apache 2.4.6, httpd -VServer MPM: worker
выдает

2

Легко переключаться между 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

Почему, когда я пытался использовать mpm_worker или mpm_event, моя страница не работала
Leoh

0

В Apache определены 2 типа MPM (Multi-Processing Modules):

1: Prefork 2: Worker

По умолчанию Apacke настроен в предварительно форкованном режиме, то есть в непоточном предварительном форковом веб-сервере. Это означает, что каждый дочерний процесс Apache содержит один поток и обрабатывает по одному запросу за раз. Из-за этого потребляется больше ресурсов.

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

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.