ПРОЕКТЫ 


  АРХИВ 


Apache-Talk @lexa.ru 

Inet-Admins @info.east.ru 

Filmscanners @halftone.co.uk 

Security-alerts @yandex-team.ru 

nginx-ru @sysoev.ru 


  СТАТЬИ 


  ПЕРСОНАЛЬНОЕ 


  ПРОГРАММЫ 



ПИШИТЕ
ПИСЬМА












     АРХИВ :: nginx-ru
Nginx-ru mailing list archive (nginx-ru@sysoev.ru)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

proxy read timeout по GET параметру


  • To: nginx-ru@xxxxxxxxx
  • Subject: proxy read timeout по GET параметру
  • From: "cat" <nginx-forum@xxxxxxxx>
  • Date: Wed, 03 Oct 2012 18:22:26 -0400
  • Dkim-signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=tigger.jlkhosting.com; s=x; h=Date:Sender:From:Message-ID:Content-Transfer-Encoding:Content-Type:Subject:To; bh=XVHFURxXGmaSXuyp8dCp/hrX+MItCNDh5X1XKYDcwsc=; b=bYzY+yO5ydLiZfLYeI5z/Tev7YyuhTft8xU474IfyQsXIQpn9zOsVoGTSk4gjP9HiHGF0VdNVVQUMAhjtTGObsxVv8GvXRFRfniYLD6GmZ4lT/o4qqD1YyuKqu71XRpw;

Приветствую. Хочу сделать proxy_read_timeout отличный от дефолтного для
избранных пользователей, у которых начинаются проблемы с клиентом если вдруг
бэкенды думают дольше обычного. Пользователь определяется GET параметром.
Вот частично рабочий конфиг:

upstream serversInt {
        server 127.0.0.1:80;
   }

    map $arg_user $timeouts {
        default normalTimeout;
        vasya lowTimeout;
    }

    server {

        listen 127.0.0.1:8080;
        error_page 504 =200 @timeoutPage;

        error_page 598 = @$timeouts;
        location /
        {
            error_page 504 =200 @timeoutPage;
            error_page 598 = @$timeouts;
            return 598;
        }

        location @lowTimeout
        {
           error_page 504 =200 @timeoutPage;
           proxy_read_timeout 1s;
           proxy_set_header Host $host;
           proxy_pass http://serversInt;
        }

        location @normalTimeout
        {
           error_page 504 =200 @timeoutPage;
           proxy_read_timeout 5s;
           proxy_set_header Host $host;
           proxy_pass http://serversInt;
        }

        location @timeoutPage { return 200 "<timeout/>"; }
    }

Работает всё кроме обработки ошибки 504 при срабатывании таймаута бэкенда.
Появляется страница с текстом '504 Gateway Time-out' и статусом 504 вместо
ожидаемой строки <timeout/> со статусом 200. Хотя в access.log почему-то
пишется статус 200.

Posted at Nginx Forum: 
http://forum.nginx.org/read.php?21,231365,231365#msg-231365

_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://mailman.nginx.org/mailman/listinfo/nginx-ru


 




Copyright © Lexa Software, 1996-2009.