Otimize o NGinx + PHP-FPM

3

Atualmente, estou executando o Nginx + PHP-FPM no meu servidor para meus sites. Hoje, quando executo a ferramenta Apache "ab", notei tempos de resposta horríveis, em média, 5595 e máximo de 17415ms para responder.

Meu arquivo de configuração do Nginx:

worker_processes  4;
error_log  /var/log/nginx/error.log info;
events {
 worker_connections 1024;
 use epoll;
 multi_accept on;
}
http {
 server_name_in_redirect off;
 server_names_hash_max_size 10240;
 server_names_hash_bucket_size 1024;
 include    mime.types;
 default_type  application/octet-stream;
index index.html index.htm index.php;
 server_tokens off;
 sendfile on;
 tcp_nopush on;
 tcp_nodelay on;
 keepalive_timeout  15;
 gzip on;
 gzip_vary on;
 gzip_disable "MSIE [1-6]\.";
 gzip_proxied any;
 gzip_http_version 1.1;
 gzip_min_length  1400;
 gzip_comp_level  9;
 gzip_buffers  16 8k;
 gzip_types    text/plain text/xml text/css application/x-javascript application/xml image/png image/x-icon image/gif image/jpeg application/xml+rss text/javascript application/atom+xml;
 ignore_invalid_headers on;
 client_header_timeout  10m;
 client_body_timeout 10m;
 send_timeout     10m;
 recursive_error_pages on;

 keepalive_requests 100;
 reset_timedout_connection on;
 connection_pool_size  256;
 client_header_buffer_size 256k;
 large_client_header_buffers 4 256k;
 client_max_body_size 200M; 
 client_body_buffer_size 128k;
 request_pool_size  32k;
 output_buffers   4 32k;
 postpone_output  1460;
 proxy_temp_path  /tmp/nginx_proxy/;
 client_body_in_file_only on;
 log_format bytes_log "$msec $bytes_sent .";

 ## Proxy options
  proxy_buffering           on;
  proxy_cache_min_uses       3;
  proxy_cache_path          /etc/nginx/proxy_temp/ levels=1:2 keys_zone=cache:10m inactive=10m max_size=1000M;
  proxy_cache_valid         any 10m;
  proxy_ignore_client_abort off;
  proxy_intercept_errors    on;
  proxy_next_upstream       error timeout invalid_header;
  proxy_redirect            off;
  proxy_set_header          X-Forwarded-For $remote_addr;
  proxy_connect_timeout     60;
  proxy_send_timeout        60;
  proxy_read_timeout        60;

 include "/etc/nginx/vhosts/*";
}

Minha configuração do PHP-FPM (somente parâmetros relevantes):

pm = dynamic
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 5
pm.max_spare_servers = 50
[..]
php_admin_value[cgi.fix_pathinfo] = 0
php_admin_value[memory_limit] = 128M

Meu servidor

CPU Intel i3-540 3.06GHz with 4 processors
6GB RAM
CentOS 5.6 x64

# ulimit -n
65535

Benchmark gráfico link

Quase esqueci, o php-fpm é tratado pelo nginx:

server {
[..]          

         location ~ \.php$ {
                fastcgi_split_path_info ^(.+\.php)(.*)$;

               fastcgi_pass   127.0.0.1:9000;
               fastcgi_index  index.php;
               include fastcgi_params;
              fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
                fastcgi_param PATH_TRANSLATED $document_root$fastcgi_script_name;
               fastcgi_param SERVER_NAME $http_host;
               fastcgi_ignore_client_abort off;
         }
[..]
        }

Alguém tem alguma dica de como eu posso otimizá-lo?

    
por Julio Vedovatto 20.10.2011 / 04:07

2 respostas

5

Você está testando o PHP, não o Nginx. Para esperar mais de 600 solicitações por segundo com PHP, é necessário um código muito sólido e um servidor bastante rápido.

Onde você provavelmente está errado, você acha que o Nginx é como o Apache - o que está muito longe da verdade. Em uma configuração típica, o Apache irá embutir o executável PHP dentro de seus próprios processos.

Você diz the php-fpm is handled by nginx: , mas não é. O PHP é passado via fastcgi para php-fpm. Fastcgi é apenas um protocolo de comunicação. O PHP é manipulado pelo próprio PHP e se você quiser otimizá-lo, você deve otimizar seu código PHP.

    
por 20.10.2011 / 16:45
1

Seu pm.max_spare_servers = 50 é muito alto. Tente com esta configuração:

pm = dynamic
pm.max_children = 30
pm.start_servers = 2
pm.min_spare_servers = 2
pm.max_spare_servers = 4
pm.max_requests = 500

leia isso para entender os parâmetros e como calculá-los.

    
por 02.12.2013 / 11:42