Sự cố Php5-fpm nếu nhiều khách truy cập


8

Tôi quyết định đổi OP của mình thành Nginx từ Litespeed vì tôi đã đọc nhiều về tài nguyên thấp mà Nginx sẽ có giá.

Tôi đang chạy một trang Wordpress với 500 người dùng trực tuyến

Được rồi, cảm ơn các bạn đã giúp đỡ rất nhiều :) Tôi đã chỉnh sửa một số thứ.

Tôi cũng có một số câu hỏi:

Tôi có phải loại bỏ; trước chiều cài đặt? Tôi loại bỏ nó Những gì cấu hình đếm? Tôi đã nhận được hai cgi nhanh một trong / etc / php5 / fpm được gọi là php-fpm.conf và một trong /etc/php5/fpm/pool.d được gọi là www.conf?

Tôi đã thử cấu hình mới qua đêm và khi tôi thức dậy, tôi đã có một trang trống. Hàng đầu:

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

Tôi nghĩ rằng việc sử dụng cpu bây giờ thấp hơn, nhưng điều đó không khắc phục được sự cố ...

Cấu hình của tôi bây giờ là: 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;

cấu hình 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

Mashine: Dualcore 4gb ram


Nhật ký lỗi PHP-FPM nói gì?
devicenull

Chỉ có bản ghi về khi tôi khởi động lại fpm một số khác ... [04-tháng 4 năm 2012 13:46:44] THÔNG BÁO: Chấm dứt ... [04-tháng 4 năm 2012 13:46:44] THÔNG BÁO: thoát, tạm biệt -tạm biệt! [04-April-2012 13:46:44] THÔNG BÁO: fpm đang chạy, pid 1744 [04-April-2012 13:46:44] THÔNG BÁO: sẵn sàng xử lý các kết nối [04-April-2012 13:48:57] THÔNG BÁO: [pool www] con 1748 đã thoát với mã 0 sau 132.647614 giây kể từ khi bắt đầu [04-tháng 4 năm 2012 13:48:57] THÔNG BÁO: [pool www] con 1829 bắt đầu
chillah

Tôi chỉ nhận thấy rằng php fpm gặp sự cố nhanh hơn nếu tôi tắt / bật hoặc chỉnh sửa các tập tin wordpress của mình. Nhưng tôi không chắc chắn 100% ...
chillah

Bạn vẫn nhận được các tai nạn? Bạn đã kiểm tra việc sử dụng APC? Thông thường, bạn xác định một nhóm trong một tệp cấu hình riêng biệt (nơi tất cả các cài đặt chiều của bạn đi).
Dada

Có nó vẫn gặp sự cố. Các sự cố dường như tăng lên với nhiều khách truy cập trên trang của tôi. Tôi không thấy process apcess trong "top". Làm thế nào tôi có thể kiểm tra nó? Tôi đã sử dụng cron để khởi động lại php fpm cứ sau 2 phút .... Tôi thực sự cần sớm khắc phục vấn đề đó!
chillah

Câu trả lời:


10

Không rõ liệu bạn có đang sử dụng bất kỳ caccode opcode nào không APC. Trước hết, làm cho nó được kích hoạt. Điều chỉnh bộ nhớ của nó để tránh phân mảnh. Ngoài ra, sử dụng ổ cắm, không phải kết nối http từ nginxđến php5-fpmvà đặt ổ cắm đó vào /dev/shm. Trong nginx, sử dụng fastcgi_pass unix:/dev/shm/php5-fpm.sock;và thay đổi cấu hình của php5-fpm cho phù hợp.

Hãy thử hạ pm.max_childrenxuống một cái gì đó thực tế hơn như 30-40-50-60 và xem tải và bộ nhớ trống với free -m. Xem nếu khách hàng nhận được bất kỳ lỗi 502/504. Thấp hơn pm.start_servers, tối thiểu và max_spare tương ứng (15, 5, 25).

Nếu có rất nhiều người dùng ẩn danh, hãy xem xét sử dụng bất kỳ plugin bộ nhớ đệm cho wordpress như WP-FFPC, WP Super Cachehoặc tương đương.

Vô hiệu hóa gzipping nếu bạn đã bật nó trong nginx.

Có lẽ bạn cần điều chỉnh fastcgi_buffer_sizefastcgi_bufferstùy chọn trong nginx.

Kiểm tra xem bạn đã bật Bộ đệm truy vấn và đủ trên Mysql chưa.

Có hệ thống giám sát như muninđược cài đặt trên trang web để kiểm tra tải / tiêu thụ bộ nhớ / độ trễ, v.v.


Kết nối giữa nginx và php5-fpm có thể không phải là HTTP mà chỉ là TCP. JFYI.
Aykut Çevik

4

Máy chủ của bạn có khả năng bị lỗi khi hết bộ nhớ để chạy các quy trình php. Cài đặt php5-fpm của bạn dường như quá hào phóng đối với RAM 4GB. Tôi đã có rất nhiều khó khăn để đến các cấu hình php5-fpm tối ưu (đối với ram 32 GB và + 1K người dùng trực tuyến, đây là các thông số có liên quan của tôi:

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

Cũng đừng quên đặt thời gian chờ kết thúc yêu cầu để tránh tình trạng thiếu bộ nhớ do các quá trình nhàn rỗi:

request_terminate_timeout = 120s

Bất kỳ thời gian chờ nào bạn sử dụng trong chỉ thị trên phải phù hợp với chỉ thị max_execut_time trong php.ini của bạn.

Đối với nginx, bật gzip là một ý tưởng rất hay: Nó rất rẻ CPU và tiết kiệm được băng thông máy chủ của bạn.

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

Chúc may mắn


Tôi đã thử cấu hình của bạn qua đêm, cpu dường như việc sử dụng dường như thấp hơn bây giờ mà không sửa được các trang trống và các sự cố. Đây là một bộ đếm Ip Hình ảnh: abload.de/img/unbenanntsgyxi.png
chillah

Tôi đồng ý với khuyến nghị nên đặt request_terminate_timeout, nhưng lý do của bạn không chính xác;) Lệnh này là để giết một tiến trình đang chạy sau một khoảng thời gian CPU nhất định, như một biện pháp an toàn khi PHP max_execution_timekhông thể (có giá trị nhỏ hơn một chút để có được cơ hội đầu tiên) [nguồn ]. "Để tránh tình trạng thiếu bộ nhớ do các quá trình nhàn rỗi", chỉ thị sử dụng là pm.process_idle_timeout = 40 [xem câu trả lời này ].
tanius

1

Tôi sẽ đề nghị sử dụng pm = ondemand và đảm bảo kích thước của memory_limit trong php có thể tương đương với bộ nhớ của máy.

Đối với một máy 4GB có 128 MB trong quy trình PHP sẽ có khoảng ~ 24 máy chủ PHP-FPM mà bạn có thể chạy, điều này thật tuyệt vì máy chủ sẽ xác định số lượng máy chủ tối đa đó và tạo mới khi tải tăng lên.


1
Đồng ý rằng trình quản lý quy trình ondemand PHP-FPM là lựa chọn tốt hơn trong hầu hết các trường hợp. Nhưng tối đa của nó. số lượng các quy trình con không thể được tính như thế này: memory_limitlà mức tối đa tuyệt đối mà một quy trình PHP có thể tiêu thụ trước khi chấm dứt mạnh mẽ. Trung bình, họ tiêu thụ ít hơn nhiều.
tanius

1
Và dù sao , bộ nhớ thường không phải là yếu tố giới hạn cho max. trẻ em, thay vì lõi CPU. Tối đa số lượng con nên được đặt thành khoảng. Số lượng lõi CPU, cộng với một số ít để bù cho chờ đợi IO, v.v. Không có gì nhanh hơn tải CPU 100%, đó chỉ là sự khác biệt giữa chờ trong hàng đợi và phục vụ chậm song song với chuyển đổi.
tanius
Khi sử dụng trang web của chúng tôi, bạn xác nhận rằng bạn đã đọc và hiểu Chính sách cookieChính sách bảo mật của chúng tôi.
Licensed under cc by-sa 3.0 with attribution required.