em Sem categoria

Apache tuning ( customizando o Apache para melhorar a performance do servidor )

Apache Tuning – ( melhorando a performance do Apache )
=============================================
O segredo para o bom funcionamento de um Apache Web Server é sua customização de acordo com os recursos de hardware disponíveis. Neste documento vamos fazer um abordagem rápida sobre estas customizações com um exemplo prático de como fazer isto.

– Hardware utilizado para o teste
Intel Celerom 2.2 Ghz single core
2 GB RAM
HDD 250 GB

– Sistema Operacional
CentOS 5
Kernel 2.6.18

– Recursos de hardware – RAM
Um dos fatores que afetam  a performance de um servidor Apache é a memória RAM. O Apache aloca e usa recursos da memória RAM para disponibilizar os resultados das requisições HTTP feitas pelos usuários, e quanto maior a quantidade de requisições, mais recursos você irá precisar para ter seu servidor Apache saudavél. Exemplo digamos que você tenha um portal que tenha em média 10.000 pageviews /dia com um banco de dados MySQL no qual o arquivo que indexa o conteúdo é um script PHP que faz em média 30 Querys. Para isso você irá precisar de uma máquina com as seguintes configurações:

Intel Xeon 3.2 Ghz ( single core / melhor se for uma máquina com dois núcleos )
4 GB RAM
HDD ( a quantidade de espaço em disco neste caso não deverá ser levada em consideração e sim a velocidade de acesso deste HDD )

Exemplo real:
Um site que é parceiro do portal UOL possui um site que toda vez que o site cai na Home do UOL há um pico muito grande de acessos no qual o servidor não possuia os recursos necessários para segurar os acessos, resultado ? Server Down, Freeze… crash. Solução ?? Aumentar a quantidade de memória para 8 GB e trocar o processador de um single Xeon para um Dual Xeon Dual Core.

Falando no geral, o I/O de disco vêm em segundo lugar após do trio RAM/CPU/Network link.

Configurando o prefork
Abaixo daremos um exemplo básico dos parâmetros do prefork

<IfModule prefork.c>
StartServers            8
MinSpareServers         5
MaxSpareServers        20
MaxClients            150
MaxRequestsPerChild  1000
</IfModule>

#<IfModule worker.c>
#  StartServers            2
#  MaxClients            150
# MinSpareThreads        25
# MaxSpareThreads        75
#ThreadsPerChild        25
#MaxRequestsPerChild     0
#</IfModule>

#<IfModule mpm_winnt.c>
# ThreadsPerChild       250
# MaxRequestsPerChild     0
#</IfModule>

Como utilizaremos o prefork, podemos comentar o worker e o mpm_winnt ( este é utilizando para o Apache no Windows )

MaxClients
O parâmetro MaxClients é o número máximo de conexões simultâneas no servidor Apache, esta diretiva é fundamental para o funcionamento do servidor Apache.

Equação para o MaxClients

MaxClients = (RAM – tamanho_de_todos_outros_processos_do_servidor ) / ( tamanho_dos_processos_do_apache )

Para conseguir detectar estes processos utilize os comandos abaixo:

ps -ylC httpd –sort:rss ( para encontrar  o tamanho dos processos. Divida o número por 1024 para verificar o valor em Megabytes );

free -m ( determina a quantidade de buffers/cache utilizados )

vmstat 2 5( mostra o número de processos rodando, blocados, aguardando processos, e entrada e saída da área de swap ).

Nossos exemplo para nossos servidor:

<IfModule prefork.c>
StartServers            8
MinSpareServers         5
MaxSpareServers        20
MaxClients            450
MaxRequestsPerChild  1000
</IfModule>

KeepAlive off
KeepAliveTimeout 15
MaxKeepAliveRequests 80
Timeout 45

*Quando utilizar o prefork é recomendado desabilitar o KeepAlive,

Referência
: http://www.devside.net/articles/apache-performance-tuning

Outros referências:
http://blogcritics.org/archives/2006/01/27/1757402.php