Большое количество waiting
Skom
nginx-forum на nginx.us
Вт Янв 18 16:30:54 MSK 2011
Здравствуйте.
Ситуация схожая с темой
http://forum.nginx.org/read.php?21,137710,137710#msg-137710
Однако, проявляется только с 8-й ветки.
Долго не мог понять в чём, собственно,
дело. Waiting растут как на дрожжах. Где-то
на миллион каждую неделю.
Больше двух миллионов не было, так как
на всякий случай рестартил nginx. Релоад
не помогает.
На быстродействие, вроде, не влияет. В
кору не падает. Иногда сегфолт, но
редко. Я вообще заметил только по
странному графику какти :)
На ветке 0.9 та же фигня.
До сегодняшнего дня грешил на свои
скрипты, ну может что там напортачил.
Однако, накатив с утра интереса ради
0.7.68, увидел, что все грабли тут же
исчезли. Уже 5 часов всё в пределах 1000
коннектов и количество не растёт.
Возможно, не все директивы конфига
правильно понимаются старшими ветками,
либо я что-то натупил с конфигом. Но всё
ж таки хочется понять в чём дело.
Апача нет, всё через php-fpm.
Там два пула. Один на 9000 порту, второй на
9001. Отличаются только register_globals.
Конфиги.
------------------------------------------
nginx -V
nginx version: nginx/0.7.68
built by gcc 4.4.3 (Ubuntu 4.4.3-4ubuntu5)
TLS SNI support enabled
configure arguments: --prefix=/usr --conf-path=/etc/nginx/nginx.conf
--http-log-path=/var/log/nginx/access_log
--error-log-path=/var/log/nginx/error_log --pid-path=/var/run/nginx.pid
--http-client-body-temp-path=/var/tmp/nginx/client
--http-proxy-temp-path=/var/tmp/nginx/proxy
--http-fastcgi-temp-path=/var/tmp/nginx/fastcgi --with-md5-asm
--with-md5=/usr/include --with-sha1-asm --with-sha1=/usr/include
--with-poll_module --with-http_ssl_module --with-http_realip_module
--with-http_addition_module --with-http_sub_module
--with-http_gzip_static_module --with-http_stub_status_module
--with-http_random_index_module --with-http_secure_link_module
--with-http_gzip_static_module
--add-module=/usr/src/web/masterzen-nginx-upload-progress-module-2bf172d
-----------------------------------------
cat /etc/nginx/nginx.conf
user nginx hosting;
worker_processes 16;
worker_rlimit_nofile 16384;
worker_priority 5;
worker_rlimit_core 500M;
working_directory /var/log/nginx/cores/;
error_log /var/log/nginx/default/error_log info;
pid /var/run/nginx.pid;
events {
worker_connections 8192;
}
http {
include mime.types;
default_type application/octet-stream;
log_format download
'$remote_addr - $remote_user [$time_local] '
'"$request" $status $bytes_sent '
'"$http_referer" "$http_user_agent" '
'"$http_range" "$sent_http_content_range"';
log_format main
'$remote_addr $host - [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_host" $request_time '
'"$http_x_forwarded_for" "$http_via" "$gzip_ratio"';
access_log /var/log/nginx/default/access_log main;
client_max_body_size 20M;
client_header_timeout 60;
client_body_timeout 60;
large_client_header_buffers 16 16K;
send_timeout 120;
proxy_read_timeout 180;
proxy_connect_timeout 60;
proxy_send_timeout 180;
proxy_buffer_size 64k;
proxy_buffers 64 512k;
proxy_busy_buffers_size 1024k;
msie_padding on;
gzip on;
gzip_min_length 1024;
gzip_buffers 32 64k;
gzip_types application/x-javascript text/css
text/xml text/plain;
sendfile on;
tcp_nopush on;
tcp_nodelay on;
output_buffers 32 256k;
postpone_output 1460;
reset_timedout_connection on;
keepalive_timeout 30;
server_names_hash_max_size 1024;
server_names_hash_bucket_size 512;
merge_slashes on;
upload_progress upload_zone_dc 1M;
upload_progress upload_zone_secure_overhit 1M;
server {
listen 127.0.0.1;
server_name localhost;
access_log off;
location ^~ /stub_status {
stub_status on;
allow 127.0.0.1;
deny all;
}
location / { deny all; }
}
server {
listen xxx.xxx.xxx.xxx default;
server_name _;
access_log /var/log/nginx/default/access_log main;
root /usr/html;
index index.html;
}
include /etc/nginx/sites-enabled/*;
}
-------------------------------------------------------------------
Типичный сервер из sites-enabled
cat xxxxxxx.ru
server {
listen xxx.xxx.xxx.xxx:80;
server_name xxxxxxx.ru;
charset utf-8;
access_log /var/log/nginx/xxxxxxx.ru/access_log;
error_log /var/log/nginx/xxxxxxx.ru/error_log;
root /.1/xxxxxxx;
index m.php main.php index.html index.htm
index.php;
location ~* /\. { deny all;}
location ~ \.php$ {
fastcgi_pass localhost:9001;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME
/.1/xxxxxxx$fastcgi_script_name;
fastcgi_intercept_errors on;
include
/etc/nginx/fastcgi_params;
}
location ^~ /Inc {
auth_basic "xxxxxxx.ru staff";
index tools.php;
auth_basic_user_file
/.1/xxxxxxx/admin/.accesslist;
location ~* /\. { deny all;}
}
}
server {
listen xxx.xxx.xxx.xxx:80;
server_name static.xxxxxxx.ru;
charset UTF-8;
root /.1/xxxxxxx/Static;
index main.php index.html index.htm
index.php;
location ~* /\. { deny all;}
location ~* \.(ico|css|js|gif|jpe?g|png)$ {
expires 1w;
add_header Cache-Control public;
}
}
-----------------------------------------------------------------
cat fastcgi.conf
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
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_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;
# PHP only, required if PHP was built with --enable-force-cgi-redirect
fastcgi_param REDIRECT_STATUS 200;
------------------------------------------------------------------------------
Posted at Nginx Forum: http://forum.nginx.org/read.php?21,167196,167196#msg-167196
Подробная информация о списке рассылки nginx-ru