Re: Периодические подвисания при загрузке статики в nginx

Михаил Монашёв postmaster at softsearch.ru
Tue Feb 17 00:03:18 MSK 2009


Здравствуйте, Алексей.

Судя по http://tr.xtlt.ru/nginx_status нагрузка небольшая. Возможно
просто не хватает каких-то буферов OS или firewall-е ? Про тюнинг
FreeBSD тут http://www.profyclub.org/articles/290/3037 . Про Линух не
знаю где аналогичное поискать...

АЗ> Приветствую всех, возник следующий вопрос
АЗ> В городской сети поднят торрент-трекер, 20000 пользователей,
АЗ> примерно 5000 уников в сутки, и 4000 одновременно подключенных
АЗ> торрент клиентов.
АЗ> Все это реализовано на nginx + fast-cgi, fcgi и nginx
АЗ> прикручены через unix socket, движек трекера - torrentpier.
АЗ> Конфигурация железки: 2*XeonE5410 / 8Gb / RAID0+1
АЗ> В пик нагрузки начал наблюдать такие проблемы, странички
АЗ> через раз то открываются с отличной скорость, то зависает на
АЗ> загрузке от 10 до 200 секунд, причем после загрузки показывается
АЗ> что пхп генерится как и обычно за 0,056сек. 
АЗ> Попробовал испытать через ab просто статичную картинку,
АЗ> эффект тотже, просто наглухо виснет тест и все. В это время в
АЗ> нетстате клиента видно что соединения висят в SYN_SENT.

АЗ> Перепробовал уже большинство возможных вариантов найденных в
АЗ> инете, ничего не дает улучшения в производительности.
АЗ> Может кто сталкивался с подобной проблемой, подскажите решение.

АЗ> nginx version: nginx/0.7.34

АЗ> Вот примерный конфиг этого чуда:
АЗ> user nginx nginx;
АЗ> worker_processes 50;
АЗ> worker_rlimit_nofile 20192;

АЗ> error_log /var/log/nginx/error_log info;

АЗ> events {
АЗ> ═══ worker_connections═ 50192;
АЗ> ═══ use epoll;
АЗ> }

АЗ> http {
АЗ> ═══ include═══ ═══ /etc/nginx/mime.types;
АЗ> ═══ default_type═══ application/octet-stream;
АЗ> ═══ client_max_body_size 1000m;
АЗ> ═══════ server_names_hash_bucket_size 64;

АЗ> ═══ log_format main
АЗ> ═══ ═══ '$remote_addr - $remote_user [$time_local] '
АЗ> ═══════ ═══ '"$request" $status $bytes_sent '
АЗ> ═══ ═══ '"$http_referer" "$http_user_agent" '
АЗ> ═══ ═══ '"$gzip_ratio"';
АЗ> ═══ ═══ ═══ ═══ ═══ ═══ ═══ ═══ ═══ ══════ 
АЗ> ═══ client_header_timeout═══ 3m;
АЗ> ═══ client_body_timeout═══ 3m;
АЗ> ═══ send_timeout═══ ═══ 3m;

АЗ> ═══ connection_pool_size═══ ═══ 2024;
АЗ> ═══ client_header_buffer_size═══ 1k;
АЗ> ═══ large_client_header_buffers═══ 4 2k;
АЗ> ═══ request_pool_size═══ ═══ 4k;

АЗ> ═══ gzip off;
АЗ> #═══ gzip_min_length═══ 1100;
АЗ> #═══ gzip_buffers═══ 4 8k;
АЗ> #═══ gzip_types═══ text/plain;

АЗ> ═══ output_buffers═══ 1 32k;
АЗ> ═══ postpone_output═══ 1460;

АЗ> ═══ sendfile═══ on;
АЗ> ═══ tcp_nopush═══ on;
АЗ> ═══ tcp_nodelay═══ on;

АЗ> ═══ keepalive_timeout═══ 0;
АЗ> ═══════ lingering_time 30;
АЗ> ═══════ lingering_timeout 2;
АЗ> ═══════ reset_timedout_connection on;

АЗ> #═══ ignore_invalid_headers═══ on;

АЗ> ═══ index index.html;

АЗ> ═══ server {
АЗ> ═══════════════ listen 80;

АЗ> ═══════════════ access_log off;
АЗ> #═══════════════ access_log /var/log/nginx/access_tr.log;
АЗ> ═══════════════ error_log /var/log/nginx/error_tr.log;
АЗ> ═══ ═══ server_name_in_redirect off;
АЗ> ═══════════════ server_name
АЗ> tltorrent.ruwww.tltorrent.rutltorrent.net.ruwww.tltorrent.net.rutr.xtlt.rutest.tr;

АЗ> ═══ ═══ error_page═ 502═ /errors/502.html;
АЗ> ═══ ═══ error_page═ 403═ /errors/403.html; 
АЗ> ═══ ═══ 
АЗ> ═══ ═══ location = /nginx_status {
АЗ> ═══════ ═══ ═══════ stub_status on;
АЗ> ═══════════════ ═══ access_log══ off;
АЗ> ═══ ═══════════════ allow all;
АЗ> ═══ ═══════ }═══ 
АЗ> ═══ ═══ 
АЗ> ═══ ═══ ═══ location / {
АЗ> ═══════════════════ root══ /var/www/tltorrent;
АЗ> ═══════════════════ index═ index.html index.htm index.php;
АЗ> ═══════════════ }

АЗ> ═══════════════ location ~ .php$ {
АЗ> #═══ ═══ fastcgi_pass══ 127.0.0.1:1026;
АЗ> ═══════════════ fastcgi_pass unix:/tmp/fcgi.sock;

АЗ> ═══════════════ fastcgi_index═ index.php;

АЗ> ═══ ═══ fastcgi_connect_timeout 60;
АЗ> ═══ ═══════ fastcgi_read_timeout 60;
АЗ> ═══════ ═══ fastcgi_send_timeout 60;

АЗ> ═══════════════ fastcgi_param═ SCRIPT_FILENAME═
АЗ> /var/www/tltorrent$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;

АЗ> ═══════════════ 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;
АЗ> ═══ ═══ #$http_x_forwarded_host;
АЗ> ═══════════════ fastcgi_param═ HTTP_HOST═══════ $http_host;
АЗ> ═══ ═══ #$http_x_forwarded_host;

АЗ> ═══════════════ }
АЗ> ═══════════════ location /forum/ub/ {
АЗ> ═══════════════════ rewrite ^/forum/ub/(.*).png$ /forum/ub/ub.php?u=$1;
АЗ> ═══════════════ }
АЗ> ═

АЗ> ═══════ }



  

--

С уважением,
Михаил Монашёв, SoftSearch.ru
mailto:postmaster at softsearch.ru
ICQ# 166233339
http://michael.mindmix.ru/
Без бэкапа по жизни.






More information about the nginx-ru mailing list