Php5-fpm Crash si beaucoup de visiteurs


8

J'ai décidé de changer mon OP en Nginx de Litespeed parce que j'ai beaucoup lu sur les faibles ressources que Nginx coûterait.

Je gère un site Wordpress avec 500 utilisateurs en ligne

D'accord merci les gars pour cette aide :) J'ai édité certaines choses.

J'ai aussi quelques questions:

Dois-je retirer le; avant le pm. réglages? Je l'ai supprimé Quelle est la configuration importante? J'ai obtenu deux cgi rapides un dans / etc / php5 / fpm appelé php-fpm.conf et un dans /etc/php5/fpm/pool.d appelé www.conf?

J'ai essayé la nouvelle configuration pendant la nuit et quand je me réveille, j'ai déjà une page blanche. Haut:

top - 13:55:27 up 1 day, 19:28,  2 users,  load average: 0.18, 0.36, 0.19
Tasks:  84 total,   1 running,  83 sleeping,   0 stopped,   0 zombie
Cpu(s):  0.2%us,  0.0%sy,  0.0%ni, 99.8%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:   3974264k total,  1051360k used,  2922904k free,   162380k buffers
Swap:  3998700k total,        0k used,  3998700k free,   609220k cached

  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
 1857 www-data  20   0  193m  55m  22m S    0  1.4   0:04.67 php5-fpm
    1 root      20   0  8356  808  680 S    0  0.0   0:01.37 init
    2 root      20   0     0    0    0 S    0  0.0   0:00.00 kthreadd

Je pense que l'utilisation du processeur est désormais plus faible, mais cela ne résout pas le problème ...

Mes configurations sont maintenant: php-fpm.conf

    ;;;;;;;;;;;;;;;;;;;;;
; FPM Configuration ;
;;;;;;;;;;;;;;;;;;;;;

; All relative paths in this configuration file are relative to PHP's install
; prefix (/usr). This prefix can be dynamicaly changed by using the
; '-p' argument from the command line.

; Include one or more files. If glob(3) exists, it is used to include a bunch of
; files from a glob(3) pattern. This directive can be used everywhere in the
; file.
; Relative path can also be used. They will be prefixed by:
;  - the global prefix if it's been set (-p arguement)
;  - /usr otherwise
;include=/etc/php5/fpm/*.conf

;;;;;;;;;;;;;;;;;;
; Global Options ;
;;;;;;;;;;;;;;;;;;

[global]
; Pid file
; Note: the default prefix is /var
; Default Value: none
pid = /var/run/php5-fpm.pid

; Error log file
; If it's set to "syslog", log is sent to syslogd instead of being written
; in a local file.
; Note: the default prefix is /var
; Default Value: log/php-fpm.log
error_log = /var/log/php5-fpm.log

; syslog_facility is used to specify what type of program is logging the
; message. This lets syslogd specify that messages from different facilities
; will be handled differently.
; See syslog(3) for possible values (ex daemon equiv LOG_DAEMON)
; Default Value: daemon
;syslog.facility = daemon

; syslog_ident is prepended to every message. If you have multiple FPM
; instances running on the same server, you can change the default value
; which must suit common needs.
; Default Value: php-fpm
;syslog.ident = php-fpm

; Log level
; Possible Values: alert, error, warning, notice, debug
; Default Value: notice
;log_level = notice

; If this number of child processes exit with SIGSEGV or SIGBUS within the time
; interval set by emergency_restart_interval then FPM will restart. A value
; of '0' means 'Off'.
; Default Value: 0
emergency_restart_threshold = 1

; Interval of time used by emergency_restart_interval to determine when 
; a graceful restart will be initiated.  This can be useful to work around
; accidental corruptions in an accelerator's shared memory.
; Available Units: s(econds), m(inutes), h(ours), or d(ays)
; Default Unit: seconds
; Default Value: 0
emergency_restart_interval = 1s

; Time limit for child processes to wait for a reaction on signals from master.
; Available units: s(econds), m(inutes), h(ours), or d(ays)
; Default Unit: seconds
; Default Value: 0
process_control_timeout = 10s

; The maximum number of processes FPM will fork. This has been design to control
; the global number of processes when using dynamic PM within a lot of pools.
; Use it with caution.
; Note: A value of 0 indicates no limit
; Default Value: 0
process.max = 150

; Send FPM to background. Set to 'no' to keep FPM in foreground for debugging.
; Default Value: yes
;daemonize = yes

; Set open file descriptor rlimit for the master process.
; Default Value: system defined value
rlimit_files = 1024

; Set max core size rlimit for the master process.
; Possible Values: 'unlimited' or an integer greater or equal to 0
; Default Value: system defined value
;rlimit_core = 0

; Specify the event mechanism FPM will use. The following is available:
; - select     (any POSIX os)
; - poll       (any POSIX os)
; - epoll      (linux >= 2.5.44)
; - kqueue     (FreeBSD >= 4.1, OpenBSD >= 2.9, NetBSD >= 2.0)
; - /dev/poll  (Solaris >= 7)
; - port       (Solaris >= 10)
; Default Value: not set (auto detection)
; events.mechanism = epoll

;;;;;;;;;;;;;;;;;;;;
; Pool Definitions ; 
;;;;;;;;;;;;;;;;;;;;

; Multiple pools of child processes may be started with different listening
; ports and different management options.  The name of the pool will be
; used in logs and stats. There is no limitation on the number of pools which
; FPM can handle. Your system will tell you anyway :)

; To configure the pools it is recommended to have one .conf file per
; pool in the following directory:
include=/etc/php5/fpm/pool.d/*.conf

request_terminate_timeout = 30s

pm.max_children = 25

; The number of child processes created on startup.
; Note: Used only when pm is set to 'dynamic'
; Default Value: min_spare_servers + (max_spare_servers - min_spare_servers) / 2
pm.start_servers = 5

; The desired minimum number of idle server processes.
; Note: Used only when pm is set to 'dynamic'
; Note: Mandatory when pm is set to 'dynamic'
pm.min_spare_servers = 2

; The desired maximum number of idle server processes.
; Note: Used only when pm is set to 'dynamic'
; Note: Mandatory when pm is set to 'dynamic'
pm.max_spare_servers = 5

; The number of seconds after which an idle process will be killed.
; Note: Used only when pm is set to 'ondemand'
; Default Value: 10s
pm.process_idle_timeout = 10s;

fastcgi_params:

fastcgi_param   QUERY_STRING        $query_string;
fastcgi_param   REQUEST_METHOD      $request_method;
fastcgi_param   CONTENT_TYPE        $content_type;
fastcgi_param   CONTENT_LENGTH      $content_length;

fastcgi_param   SCRIPT_FILENAME     $request_filename;
fastcgi_param   SCRIPT_NAME     $fastcgi_script_name;
fastcgi_param   REQUEST_URI     $request_uri;
fastcgi_param   DOCUMENT_URI        $document_uri;
fastcgi_param   DOCUMENT_ROOT       $document_root;
fastcgi_param   SERVER_PROTOCOL     $server_protocol;

fastcgi_param   GATEWAY_INTERFACE   CGI/1.1;
fastcgi_param   SERVER_SOFTWARE     nginx/$nginx_version;

fastcgi_param   REMOTE_ADDR     $remote_addr;
fastcgi_param   REMOTE_PORT     $remote_port;
fastcgi_param   SERVER_ADDR     $server_addr;
fastcgi_param   SERVER_PORT     $server_port;
fastcgi_param   SERVER_NAME     $server_name;

#fastcgi_param  HTTPS           $https;

# PHP only, required if PHP was built with --enable-force-cgi-redirect
fastcgi_param   REDIRECT_STATUS     200;

fastcgi_connect_timeout 60;
fastcgi_send_timeout 180;
fastcgi_read_timeout 180;
fastcgi_buffer_size 128k;
fastcgi_buffers 4 256k;
fastcgi_busy_buffers_size 256k;
fastcgi_temp_file_write_size 256k;
fastcgi_intercept_errors on;

config nginx:

user www-data;
worker_processes 2;
pid /var/run/nginx.pid;

events {
    worker_connections 500;
    # multi_accept on;
}

http {

    ##
    # Basic Settings
    ##

    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 40;
    types_hash_max_size 2048;
    server_tokens off;

    # server_names_hash_bucket_size 64;
    # server_name_in_redirect off;

    include /etc/nginx/mime.types;
    default_type application/octet-stream;

    ##
    # Logging Settings
    ##

    # access_log /var/log/nginx/access.log;
    # error_log /var/log/nginx/error.log;

    ##
    # Gzip Settings
    ##

    gzip on;
    gzip_disable "msie6";

 gzip_vary on;
 gzip_proxied any;
 gzip_comp_level 9;
 gzip_buffers 16 8k;
 gzip_http_version 1.1;
 gzip_types text/plain text/css application/json application/x-javascript text/$

www.conf

; Start a new pool named 'www'.
; the variable $pool can we used in any directive and will be replaced by the
; pool name ('www' here)
[www]

user = www-data
group = www-data


pm = dynamic

pm.max_children = 25

pm.start_servers = 5

pm.min_spare_servers = 2

pm.max_spare_servers = 5

pm.process_idle_timeout = 10s;

pm.max_requests = 100

request_terminate_timeout = 120s

The Mashine: Dualcore 4 Go de RAM


Que dit le journal des erreurs PHP-FPM?
devicenull

Theres seulement le dossier sur le moment où je redémarre le fpm un autre ... [04-Apr-2012 13:46:44] AVIS: Fin ... [04-Apr-2012 13:46:44] AVIS: sortie, bye -au revoir! [04-Apr-2012 13:46:44] AVIS: fpm est en cours d'exécution, pid 1744 [04-Apr-2012 13:46:44] AVIS: prêt à gérer les connexions [04-Apr-2012 13:48:57] AVIS: [pool www] enfant 1748 est sorti avec le code 0 après 132.647614 secondes après le début [04-avr-2012 13:48:57] AVIS: [pool www] enfant 1829 a commencé
chillah

Je viens de remarquer que php fpm se bloque plus rapidement si je désactive / active ou modifie mes fichiers wordpress. Mais je ne suis pas sûr à 100% ...
chillah

Obtenez-vous toujours les accidents? Avez-vous vérifié l'utilisation de APC? Habituellement, vous définissez un pool dans un fichier de configuration séparé (où vont tous vos paramètres pm).
Dada

Oui, ça plante toujours. Les plantages semblent augmenter avec plus de visiteurs sur ma page. Je ne vois pas le processus apc en "haut". Comment puis-je le vérifier? J'ai utilisé cron pour redémarrer php fpm toutes les 2 minutes pour l'instant .... J'ai vraiment besoin de résoudre ce problème bientôt!
chillah

Réponses:


10

Il n'est pas clair si vous utilisez un opcode cacher comme APC. Tout d'abord, activez-le. Ajustez sa mémoire pour éviter la fragmentation. Utilisez également le socket, pas la connexion http de nginxà php5-fpm, et placez ce socket sur /dev/shm. Dans nginx, utilisez fastcgi_pass unix:/dev/shm/php5-fpm.sock;et modifiez la configuration de php5-fpm en conséquence.

Essayez de descendre pm.max_childrenà quelque chose de plus réaliste comme 30-40-50-60 et voyez la charge et la mémoire libre avec free -m. Vérifiez si les clients obtiennent des erreurs 502/504. Réduisez pm.start_servers, min et max_spare en conséquence (15, 5, 25).

S'il y a beaucoup d'utilisateurs anonymes, pensez à utiliser n'importe quel plugin de mise en cache pour wordpress comme WP-FFPC, WP Super Cacheou similaire.

Désactivez le gzipping si vous l'avez activé dans nginx.

Peut-être que vous avez besoin d'ajuster fastcgi_buffer_sizeet d' fastcgi_buffersoptions dans nginx.

Vérifiez si le cache de requête est activé et suffisant sur Mysql.

Avoir un système de surveillance comme munininstallé sur le site afin de vérifier la charge / la consommation de mémoire / la latence, etc.


La connexion entre nginx et php5-fpm peut ne pas être HTTP mais juste TCP. JFYI.
Aykut Çevik

4

Votre serveur est susceptible de souffrir lorsqu'il manque de mémoire pour exécuter des processus php. Vos paramètres php5-fpm semblent être trop généreux pour 4 Go de RAM. J'ai eu beaucoup de tripotage pour arriver à des configurations optimales de php5-fpm (pour les utilisateurs en ligne de 32 Go de RAM et + 1 Ko, voici mes paramètres pertinents:

pm.max_children = 25
pm.start_servers = 5
pm.min_spare_servers = 2 
pm.max_spare_servers = 5
pm.max_requests = 100

N'oubliez pas non plus de définir un délai d'expiration de la requête pour éviter une pénurie de mémoire due à des processus inactifs:

request_terminate_timeout = 120s

Quel que soit le délai que vous utilisez dans le directoire ci-dessus, il doit être conforme à la directive max_execution_time dans votre php.ini.

En ce qui concerne nginx, avoir gzip est une très bonne idée: il est très bon marché au niveau du processeur et économise de la bande passante sur votre serveur.

   #sendfile on;
    #tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 10;
    types_hash_max_size 2048;
    # server_tokens off;
    gzip on;
    gzip_disable "msie6";

    gzip_vary on;
    gzip_proxied any;
    gzip_comp_level 9;
    gzip_buffers 16 8k;
    gzip_http_version 1.1;
    gzip_types text/plain text/css application/json application/x-javascript text/$

Bonne chance


J'ai essayé votre configuration pendant la nuit, le processeur semble être plus bas maintenant, mais il n'a pas corrigé les pages blanches et les plantages. Voici un compteur Ip Image: abload.de/img/unbenanntsgyxi.png
chillah

Je suis d'accord avec la recommandation de définir request_terminate_timeout, mais votre raison n'est pas correcte;) Cette directive est de tuer un processus en cours d'exécution après un certain temps CPU, comme une garantie lorsque PHP ne max_execution_timepeut pas (ce qui devrait avoir une valeur un peu plus petite pour obtenir le première chance) [source ]. "Pour éviter une pénurie de mémoire due à des processus inactifs", la directive à utiliser est pm.process_idle_timeout = 40 [voir cette réponse ].
tanius

1

Je suggérerais d'utiliser pm = ondemand et de m'assurer que la taille de memory_limit en php est assez importante pour la mémoire de la machine.

Pour une machine de 4 Go avec 128 Mo en processus PHP, ce serait environ ~ 24 serveurs PHP-FPM que vous pouvez avoir en cours d'exécution, ondemand est agréable car le serveur déterminerait cette quantité maximale de serveurs et en créerait de nouveaux à mesure que la charge augmente.


1
Convenez que le gestionnaire de processus PHP-FPM sur demande est le meilleur choix dans la plupart des cas. Mais son max. le nombre de processus enfants ne peut pas être calculé comme ceci: memory_limitest le maximum absolu qu'un processus PHP peut consommer avant de se terminer de force. En moyenne, ils consomment beaucoup moins.
tanius

1
Et de toute façon , la mémoire n'est généralement pas le facteur limitant pour max. enfants, plutôt des cœurs de processeur. Max. le nombre d'enfants doit être réglé à env. Nombre de cœurs du processeur, plus quelques-uns pour compenser les attentes d'E / S, etc. Rien ne va plus vite au-delà de 100% de charge du processeur, c'est juste une différence entre l'attente en file d'attente et le service parallèle lent avec la commutation.
tanius
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.