Olhando para o arquivo de configuração do Apache, vejo Prefork e Worker MPM definidos. Qual é a diferença e qual o Apache está usando?
113
Prefork e worker são dois tipos de MPM que o Apache fornece. Ambos têm seus méritos e deméritos.
Por padrão, mpm é prefork, que é seguro para threads.
O Prefork MPM usa vários processos filho com um thread cada e cada processo lida com uma conexão por vez.
O Worker MPM usa vários processos filho com muitos threads cada. Cada thread lida com uma conexão por vez.
Para obter mais detalhes, você pode visitar https://httpd.apache.org/docs/2.4/mpm.html e https://httpd.apache.org/docs/2.4/mod/prefork.html
Os Módulos de Multiprocessamento (MPMs) do Apache são responsáveis por vincular às portas de rede na máquina, aceitar solicitações e enviar filhos para lidar com as solicitações ( http://httpd.apache.org/docs/2.2/mpm.html ).
Eles são como qualquer outro módulo Apache, exceto que apenas um e apenas um MPM deve ser carregado no servidor a qualquer momento . Os MPMs são escolhidos durante a configuração e compilados no servidor usando o argumento
--with-mpm=NAME
com o script de configuração ondeNAME
é o nome do MPM desejado.O Apache usará um MPM padrão para cada sistema operacional, a menos que um diferente seja escolhido no momento da compilação (por exemplo, no Windows
mpm_winnt
é usado por padrão). Esta é a lista de sistemas operacionais e seus MPMs padrão:beos
mpm_netware
mpmt_os2
prefork
( atualização para a versão Apache ≥ 2,4 :prefork
,worker
ouevent
, dependendo capacidades da plataforma)mpm_winnt
Para verificar quais módulos são compilados no servidor, use a opção de linha de comando
-l
( aqui está a documentação). Por exemplo, em uma instalação do Windows, você pode obter algo como:A partir da versão 2.2, esta é a lista de recursos principais e módulos MPM disponíveis :
core
- Principais recursos do servidor HTTP Apache que estão sempre disponíveismpm_common
- Uma coleção de diretivas que são implementadas por mais de um módulo de multi-processamento (MPM)beos
- Este Módulo de Multiprocessamento é otimizado para BeOS.event
- Uma variante experimental do MPM trabalhador padrãompm_netware
Módulo de multiprocessamento implementando um servidor web exclusivamente encadeado otimizado para Novell NetWarempmt_os2
MPM híbrido multiprocesso, multiencadeamento para OS / 2prefork
Implementa um servidor da web pré-bifurcado sem threadmpm_winnt
- Este Módulo de Multiprocessamento é otimizado para Windows NT.worker
- Módulo de multiprocessamento implementando um servidor web híbrido multi-threaded multi-processoAgora, para a diferença entre
prefork
eworker
.O
prefork
MPMO
worker
MPM implementa um servidor híbrido multiprocessos multi-threaded e oferece melhor desempenho, portanto, deve ser preferível a menos que um esteja usando outros módulos que contenham bibliotecas não thread-safe (veja também esta discussão ou esta em Serverfault).fonte
Dê uma olhada nisso para obter mais detalhes. Refere-se a como o Apache lida com várias solicitações. A pré-bifurcação, que é o padrão, inicia vários processos do Apache (2 por padrão aqui, embora eu acredite que seja possível configurar isso por meio do httpd.conf). O Worker MPM iniciará um novo thread por solicitação, o que eu acho que é mais eficiente em termos de memória. Historicamente, o Apache usou prefork, então é um modelo mais bem testado. O encadeamento só foi adicionado no 2.0.
fonte
Para CentOS 6.xe 7.x (incluindo Amazon Linux), use:
Isso mostrará quais dos MPMs estão configurados. Pré-garfo, trabalhador ou evento. Prefork é o modelo mais antigo, threadsafe. Worker é multi-threaded e o evento suporta php-mpm, que é suposto ser um sistema melhor para lidar com threads e solicitações.
No entanto, seus resultados podem variar, com base na configuração. Eu vi muita instabilidade no php-mpm e nenhuma melhora na velocidade. Uma aranha agressiva pode exaurir o máximo de processos filhos em php-mpm com bastante facilidade.
A configuração para prefork, trabalhador ou evento é definida em sudo nano /etc/httpd/conf.modules.d/00-mpm.conf (para CentOS 6.x / 7.x / Apache 2.4).
fonte
Você pode saber se o Apache está usando pré-forma ou trabalhador, emitindo o seguinte comando
Na saída resultante, procure menções de prefork.c ou worker.c
fonte
apachectl -V
olhar a saída ao lado deServer MPM
. Também pode verificarps aux
e procurar porhttpd
ouhttpd.worker
.apache2ctl -l
não funcionou; teve que usarapachectl -l
.httpd -V
dará algo como:Server MPM: worker
É fácil alternar entre prefork ou worker mpm no Apache 2.4 no RHEL7
Verifique o tipo de MPM executando
Agora, para alterar o MPM, edite o arquivo a seguir e descomente o MPM necessário
fonte
O Apache tem 2 tipos de MPM (Módulos de Multi-Processamento) definidos:
1: Prefork 2: Trabalhador
Por padrão, o Apacke é configurado no modo pré-bifurcado, ou seja, servidor da web pré-bifurcado sem thread. Isso significa que cada processo filho do Apache contém um único thread e lida com uma solicitação por vez. Por isso, consome mais recursos.
O Apache também tem o MPM de trabalho que transforma o Apache em um servidor da web multiprocessos e multiencadeados. O Worker MPM usa vários processos filho com muitos threads cada.
fonte