proxy read timeout по GET параметру
cat
nginx-forum at nginx.us
Wed Oct 3 22:22:26 UTC 2012
Приветствую. Хочу сделать 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