Php5-fpm Сбой, если много посетителей


8

Я решил сменить свою операционную систему на Nginx с Litespeed, потому что много читал о низком ресурсе, который будет стоить Nginx.

Я управляю сайтом Wordpress с 500 пользователями онлайн

Хорошо, спасибо, ребята, за большую помощь :) Я отредактировал некоторые вещи.

У меня тоже осталось несколько вопросов:

Должен ли я удалить; до вечера настройки? Я его убрал Какой конфиг имеет значение? Я получил два быстрых cgi, один в / etc / php5 / fpm с именем php-fpm.conf и один в /etc/php5/fpm/pool.d с именем www.conf?

Я попробовал новый конфиг за ночь, и когда я проснулся, у меня уже была пустая страница. Верхний:

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

Я думаю, что использование процессора теперь ниже, но это не исправляет сбой ...

Мои конфиги сейчас: 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:

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

Машин: DualCore 4 ГБ оперативной памяти


Что говорит журнал ошибок PHP-FPM?
devicenull

Theres только запись о том, когда я перезапускаю fpm какой-то другой ... [04-Apr-2012 13:46:44] УВЕДОМЛЕНИЕ: Завершение ... [04-Apr-2012 13:46:44] УВЕДОМЛЕНИЕ: выход, пока -до свидания! [04-Apr-2012 13:46:44] ВНИМАНИЕ: fpm запущен, pid 1744 [04-Apr-2012 13:46:44] ВНИМАНИЕ: готов к обработке соединений [04-Apr-2012 13:48:57] УВЕДОМЛЕНИЕ: [pool www] ребенок 1748 вышел с кодом 0 после 132.647614 секунд от начала [04-Apr-2012 13:48:57] УВЕДОМЛЕНИЕ: [pool www] ребенок 1829 запущен
chillah

Я только заметил, что php fpm падает быстрее, если я отключаю / включаю или редактирую свои файлы WordPress. Но я не уверен на 100% ...
Чилла

Вы все еще получаете сбои? Вы проверили использование APC? Обычно вы определяете пул в отдельном конфигурационном файле (куда входят все ваши настройки PM).
Дада

Да, это все еще падает. Сбои, кажется, увеличиваются с увеличением количества посетителей на моей странице. Я не вижу APC процесс в "топ". Как я могу это проверить? Я использовал cron для перезапуска php fpm каждые 2 минуты ... Мне действительно нужно скоро исправить эту проблему!
Чилла

Ответы:


10

Не ясно, используете ли вы какой-либо опекодерский кешер APC. Прежде всего, сделайте это включенным. Отрегулируйте его память, чтобы избежать фрагментации. Кроме того, используйте сокет, а не http-соединение с nginxto php5-fpm, и поместите этот сокет в /dev/shm. В nginx используйте fastcgi_pass unix:/dev/shm/php5-fpm.sock;и измените конфигурацию php5-fpm соответствующим образом.

Попробуйте опустить pm.max_childrenчто-то более реалистичное, например, 30-40-50-60, и посмотрите на загрузку и свободную память при помощи free -m. Посмотрите, получают ли клиенты какие-либо ошибки 502/504. Lower pm.start_servers, min и max_spare соответственно (15, 5, 25).

Если есть много анонимных пользователей, рассмотреть возможность использования каких - либо плагин кэширования для WordPress , как WP-FFPC, WP Super Cacheили аналогичный.

Отключите gzipping, если он включен в nginx.

Возможно, вам нужно настроить fastcgi_buffer_sizeи fastcgi_buffersпараметры в nginx.

Проверьте, включен ли кеш запросов и достаточно ли его в Mysql.

muninУстановите систему мониторинга, подобную установленной на сайте, чтобы проверить нагрузку / потребление памяти / задержку и т. Д.


Соединение между nginx и php5-fpm может быть не HTTP, а только TCP. JFYI.
Айкут Чевик

4

Ваш сервер может страдать, когда ему не хватает памяти для запуска процессов php. Ваши настройки php5-fpm слишком велики для 4 ГБ ОЗУ. У меня было много хлопот, чтобы прийти к оптимальным конфигурациям php5-fpm (для 32 ГБ оперативной памяти и + 1K онлайн-пользователей, вот мои соответствующие параметры:

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

Также не забудьте установить таймаут завершения запроса, чтобы избежать нехватки памяти из-за неактивных процессов:

request_terminate_timeout = 120s

Независимо от того, какой тайм-аут вы используете в вышеуказанном директиве, он должен соответствовать директиве max_execution_time в вашем php.ini.

Что касается nginx, иметь gzip - очень хорошая идея: он очень дешев с точки зрения использования процессора и экономит нагрузку на ваш сервер.

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

Удачи


Я попробовал ваш конфиг на ночь, кажется, что использование процессора теперь ниже, но не исправил пустые страницы и вылеты. Вот счетчик IP-
адресов

Я согласен с рекомендацией установить request_terminate_timeout, но ваша причина не верна;) Эта директива заключается в том, чтобы завершать запущенный процесс через определенное количество процессорного времени, в качестве гарантии, когда PHP не max_execution_timeможет (который должен иметь немного меньшее значение, чтобы получить первый шанс) [источник ]. «Чтобы избежать нехватки памяти из-за незанятых процессов», используйте директиву pm.process_idle_timeout = 40 [см. Этот ответ ].
Танус

1

Я бы предложил использовать pm = ondemand и убедиться, что размер memory_limit в php соответствует памяти машины.

Для машины объемом 4 ГБ с процессором PHP объемом 128 МБ, который может быть равен ~ 24 серверам PHP-FPM, которые вы можете иметь, ondemand хорош, так как сервер определит максимальное количество серверов и создаст новые по мере увеличения нагрузки.


1
Согласитесь, что диспетчер процессов PHP-FPM ondemand является лучшим выбором в большинстве случаев. Но это макс. количество дочерних процессов не может быть вычислено следующим образом: memory_limitэто абсолютный максимум, который может потреблять процесс PHP до принудительного завершения. В среднем они потребляют намного меньше.
Танус

1
И вообще , память обычно не является ограничивающим фактором для макс. ребята, скорее процессорные ядра. Максимум. количество детей должно быть установлено на прибл. Количество ядер процессора, плюс несколько, чтобы компенсировать ожидания ввода-вывода и т. Д. Ничто не идет быстрее, чем загрузка процессора на 100%, это просто разница между ожиданием в очереди и медленным параллельным обслуживанием с коммутацией.
Танус
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.