Php5-fpm Absturz bei vielen Besuchern

8

Ich habe beschlossen, mein OP von Litespeed auf Nginx umzustellen, weil ich viel über die geringen Ressourcen gelesen habe, die Nginx kosten würde.

Ich betreibe eine Wordpress-Site mit 500 Benutzern online

Okay, danke Jungs für so viel Hilfe :) Ich habe einige Dinge bearbeitet.

Ich habe auch noch einige Fragen:

Muss ich das entfernen; vor der Uhr. die Einstellungen? Ich habe es entfernt. Welche Konfiguration zählt? Ich habe zwei schnelle CGI, eine in / etc / php5 / fpm namens php-fpm.conf und eine in /etc/php5/fpm/pool.d namens www.conf?

Ich habe die neue Konfiguration über Nacht ausprobiert und als ich aufwachte, bekam ich bereits eine leere Seite. Oben:

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

Ich denke, die CPU-Auslastung ist jetzt geringer, aber das behebt den Absturz nicht ...

Meine Konfigurationen sind jetzt: 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;

nginx config:

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 GB RAM

Chillah
quelle
Was sagt das PHP-FPM-Fehlerprotokoll?
Devicenull
Es gibt nur die Aufzeichnung darüber, wann ich die fpm neu starte ... [04-Apr-2012 13:46:44] HINWEIS: Beenden ... [04-Apr-2012 13:46:44] HINWEIS: Beenden, Tschüss -Tschüss! [04-Apr-2012 13:46:44] HINWEIS: fpm läuft, pid 1744 [04-Apr-2012 13:46:44] HINWEIS: Bereit, Verbindungen zu verarbeiten [04-Apr-2012 13:48:57] HINWEIS: [Pool www] Kind 1748 mit Code 0 nach 132.647614 Sekunden vom Start beendet [04-Apr-2012 13:48:57] HINWEIS: [Pool www] Kind 1829 gestartet
Chillah
Ich habe gerade bemerkt, dass PHP Fpm schneller abstürzt, wenn ich meine WordPress-Dateien deaktiviere / aktiviere oder bearbeite. Aber
ich bin
Bekommst du immer noch die Abstürze? Haben Sie die Verwendung von überprüft APC? Normalerweise definieren Sie einen Pool in einer separaten Konfigurationsdatei (in der alle Ihre pm-Einstellungen gespeichert sind).
Dada
Ja, es stürzt immer noch ab. Die Abstürze scheinen mit mehr Besuchern auf meiner Seite zuzunehmen. Ich sehe den APC-Prozess nicht in "oben". Wie kann ich das überprüfen? Ich habe cron verwendet, um php fpm vorerst alle 2 Minuten neu zu starten ... Ich muss dieses Problem wirklich bald beheben!
Chillah

Antworten:

10

Es ist nicht klar, ob Sie einen Opcode-Cacher wie verwenden APC. Aktivieren Sie es zunächst. Passen Sie den Speicher an, um eine Fragmentierung zu vermeiden. Verwenden Sie außerdem den Socket und nicht die http-Verbindung von nginxbis php5-fpmund setzen Sie diesen Socket auf /dev/shm. Verwenden fastcgi_pass unix:/dev/shm/php5-fpm.sock;und ändern Sie in nginx die Konfiguration von php5-fpm entsprechend.

Versuchen Sie, pm.max_childrenauf etwas Realistischeres wie 30-40-50-60 abzusenken, und sehen Sie die Last und den freien Speicher mit free -m. Überprüfen Sie, ob Clients 502/504-Fehler erhalten. Lower pm.start_servers, min und entsprechend max_spare (15, 5, 25).

Wenn es eine Menge von anonymen Benutzern ist, sollte all Caching - Plugin für Wordpress verwenden , wie WP-FFPC, WP Super Cacheoder ähnliches.

Deaktivieren Sie gzipping, wenn Sie es in nginx aktiviert haben.

Möglicherweise müssen Sie fastcgi_buffer_sizeund fastcgi_buffersOptionen in Nginx anpassen .

Überprüfen Sie, ob der Abfrage-Cache für MySQL aktiviert und ausreichend ist.

Lassen Sie ein Überwachungssystem wie muninauf der Site installieren, um Last / Speicherverbrauch / Latenz usw. zu überprüfen.

Dada
quelle
Die Verbindung zwischen nginx und php5-fpm ist möglicherweise nicht HTTP, sondern nur TCP. JFYI.
Aykut Çevik
4

Ihr Server leidet wahrscheinlich, wenn ihm der Speicher für die Ausführung von PHP-Prozessen ausgeht. Ihre PHP5-Fpm-Einstellungen scheinen für 4 GB RAM zu großzügig zu sein. Ich habe viel herumgespielt, um zu optimalen PHP5-Fpm-Konfigurationen zu gelangen (für 32-GB-RAM- und + 1K-Online-Benutzer sind hier meine relevanten Parameter:

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

Vergessen Sie auch nicht, ein Zeitlimit für die Anforderungsbeendigung festzulegen, um Speichermangel aufgrund von Leerlaufprozessen zu vermeiden:

request_terminate_timeout = 120s

Unabhängig davon, welches Zeitlimit Sie in der obigen Direktive verwenden, sollte es mit der Direktive max_execution_time in Ihrer php.ini übereinstimmen.

Was Nginx betrifft, ist es eine sehr gute Idee, gzip zu verwenden: Es ist sehr billig in Bezug auf die CPU und spart Ihrem Server viel Bandbreite.

   #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/$

Viel Glück

Alfish
quelle
Ich habe Ihre Konfiguration über Nacht ausprobiert. Die CPU scheint jetzt weniger ausgelastet zu sein, obwohl die leeren Seiten und die Abstürze nicht behoben wurden. Hier ist ein IP-
chillah
Ich bin mit der Empfehlung einverstanden request_terminate_timeout, aber Ihr Grund ist nicht korrekt;) Diese Anweisung besteht darin, einen laufenden Prozess nach einer bestimmten CPU-Zeit abzubrechen, um zu gewährleisten, dass PHPs max_execution_timedies nicht konnten (was einen etwas kleineren Wert haben sollte, um das zu erhalten) erste Chance) [Quelle ]. "Um Speichermangel aufgrund von Leerlaufprozessen zu vermeiden", lautet die zu verwendende Anweisung pm.process_idle_timeout = 40 [siehe diese Antwort ].
Tanius
1

Ich würde vorschlagen, pm = ondemand zu verwenden und sicherzustellen, dass die Größe des memory_limit in PHP dem Speicher des Computers entspricht.

Für einen 4-GB-Computer mit 128 MB PHP-Prozess, der ungefähr 24 PHP-FPM-Server umfassen kann, ist ondemand hilfreich, da der Server die maximale Anzahl von Servern ermittelt und mit zunehmender Auslastung neue Server erstellt.

OMG-1
quelle
1
Stimmen Sie zu, dass der On-Demand-Prozessmanager von PHP-FPM in den meisten Fällen die bessere Wahl ist. Aber es ist max. Die Anzahl der untergeordneten Prozesse kann nicht wie memory_limitfolgt berechnet werden: Dies ist das absolute Maximum, das ein PHP-Prozess verbrauchen kann, bevor er zwangsweise beendet wird. Im Durchschnitt verbrauchen sie viel weniger.
Tanius
1
Und überhaupt , Speicher ist normalerweise nicht der begrenzende Faktor für max. Kinder, eher CPU-Kerne. Max. Die Anzahl der Kinder sollte auf ca. CPU-Kernanzahl plus ein paar, um E / A-Wartezeiten usw. zu kompensieren. Nichts geht schneller als 100% CPU-Auslastung, es ist nur ein Unterschied zwischen dem Warten in der Warteschlange und dem langsamen parallelen Serving mit Switching.
Tanius