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
APC
? Habituellement, vous définissez un pool dans un fichier de configuration séparé (où vont tous vos paramètres pm).Réponses:
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 denginx
àphp5-fpm
, et placez ce socket sur/dev/shm
. Dans nginx, utilisezfastcgi_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 avecfree -m
. Vérifiez si les clients obtiennent des erreurs 502/504. Réduisezpm.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 Cache
ou similaire.Désactivez le gzipping si vous l'avez activé dans nginx.
Peut-être que vous avez besoin d'ajuster
fastcgi_buffer_size
et d'fastcgi_buffers
options dans nginx.Vérifiez si le cache de requête est activé et suffisant sur Mysql.
Avoir un système de surveillance comme
munin
installé sur le site afin de vérifier la charge / la consommation de mémoire / la latence, etc.la source
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:
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:
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.
Bonne chance
la source
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 nemax_execution_time
peut 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 estpm.process_idle_timeout = 40
[voir cette réponse ].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.
la source
memory_limit
est le maximum absolu qu'un processus PHP peut consommer avant de se terminer de force. En moyenne, ils consomment beaucoup moins.