Ajustando o Apache2 prefork MaxClients ServerLimit

20

Eu tenho uma máquina com 128 GB de Ram que está usando o Apache2 como servidor da Web (nesta máquina não há servidor de banco de dados, a Database Machine é uma máquina Ram de 64 GB capaz de lidar com 2000 conexões máximas). Eu vejo com uma ferramenta de monitoramento que existem no momento cerca de 44 trabalhadores ocupados e 12 trabalhadores ociosos, quais são os melhores valores teóricos para o meu módulo de prefork?

eu tenho páginas em branco às vezes carregando sites em altas horas de carga e recebo esse erro no meu log de erro do apache:

[aviso] pid filho pg 13595 sinal de saída Falha de segmentação (11)

como pode resolver este problema também?

Configuração do meu módulo Apache2 Prefork:

StartServers          3
MinSpareServers       3
MaxSpareServers       5
ServerLimit           3200
MaxClients            3100
MaxRequestsPerChild   0

Grátis -h na máquina www :

total: 128 G grátis: 97 GB (com apache2 em execução) compartilhada 0b buffers 1.9G cache 23G

Ram usado pelo Apache2 e outros programas:

Private  +   Shared  =  RAM used    Program

 96.0 KiB +  61.0 KiB = 157.0 KiB   sh
176.0 KiB +  26.0 KiB = 202.0 KiB   atd
176.0 KiB +  35.5 KiB = 211.5 KiB   acpid
208.0 KiB +  19.5 KiB = 227.5 KiB   mdadm
204.0 KiB +  30.0 KiB = 234.0 KiB   init
248.0 KiB +  62.0 KiB = 310.0 KiB   sendmail
376.0 KiB +  36.0 KiB = 412.0 KiB   dbus-daemon
388.0 KiB + 285.5 KiB = 673.5 KiB   cron (2)
820.0 KiB +  42.0 KiB = 862.0 KiB   gam_server
920.0 KiB + 108.0 KiB =   1.0 MiB   ntpd
968.0 KiB + 243.0 KiB =   1.2 MiB   getty (6)
  1.3 MiB + 351.5 KiB =   1.6 MiB   udevd (3)
  1.5 MiB + 343.0 KiB =   1.8 MiB   sendmail-msp
  2.0 MiB + 910.0 KiB =   2.9 MiB   plugin-localresources2
  3.4 MiB +  50.0 KiB =   3.4 MiB   rsyslogd
  3.6 MiB +  68.5 KiB =   3.7 MiB   bash
  1.9 MiB +   2.1 MiB =   4.0 MiB   sendmail-mta (4)
  3.8 MiB + 556.0 KiB =   4.3 MiB   sshd (2)
  3.7 MiB +   1.2 MiB =   4.8 MiB   plugin-apache2
  5.1 MiB +   1.2 MiB =   6.3 MiB   agent-service
  7.0 MiB + 654.0 KiB =   7.6 MiB   fail2ban-server
  9.6 MiB +   2.6 MiB =  12.2 MiB   proftpd (8)
 59.2 MiB +  70.0 KiB =  59.3 MiB   miniserv.pl
 96.8 MiB +   3.6 MiB = 100.4 MiB   php5-cgi (2)
196.4 MiB +  35.9 MiB = 232.3 MiB   apache2 (40)
---------------------------------
                     tot 450.0 MiB
    
por User-N 15.11.2014 / 18:45

1 resposta

60

Configurações do Preachek do Apache, de acordo com as diretrizes de ajuste de desempenho do apache

citação:

The single biggest hardware issue affecting webserver performance is RAM.
A webserver should never ever have to swap, as swapping increases the latency
of each request beyond a point that users consider "fast enough". 
This causes users to hit stop and reload, further increasing the load.
You can, and should, control the MaxClients setting so that your server does
not spawn so many children it starts swapping. This procedure for doing this
is simple: determine the size of your average Apache process, by looking at
your process list via a tool such as top, and divide this into your total 
available memory, leaving some room for other processes.

você deve configurá-lo assim com base em sua entrada para:

  • Memória total: 128 GB
  • -10% de memória para tudo, exceto o apache: 115 GB
  • Agora precisamos descobrir o quanto o processo de apache único está usando.

Para calcular isso, você pode usar o seguinte script:

pgrep apache2 | xargs -n1 -I{} cat /proc/{}/smaps | \
  awk '{if ($0 ~ /stack/) {pids+=1} else if ($0 ~/^Shared_/) 
    {shared+=$2} else if ($0 ~ /^Pss:/) {priv+=$2}} END {
      printf "%.2f MB\n",(priv+shared/(pids*pids))/1024}'

Esta é a melhor estimativa de quanto um único processo apache está usando memória ao tentar dividir proporcionalmente o uso compartilhado por número de processos apache ativos e adicioná-lo ao topo de Pss (tamanho do conjunto proporcional)

Por fim, você divide 115 GB com essa figura e obtém MaxClients/ServerLimit . A partir daqui, você pode calcular relativamente outros números como

  • StartServers 30% de MaxClients
  • MinSpareServers 5% de MaxClients
  • MaxSpareServers 10% de MaxClients
  • ServerLimit == MaxClients
  • MaxConnectionsPerChild 10000 (como alternativa conservadora para resolver possíveis problemas com aplicativos com vazamento de memória)
por 15.11.2014 / 20:41