не работает error_page 503 /503.html;

Maxim Dounin mdounin at mdounin.ru
Fri Mar 20 16:24:59 MSK 2009


Hello!

On Fri, Mar 20, 2009 at 03:09:30PM +0300, Igor Sysoev wrote:

> On Fri, Mar 20, 2009 at 01:38:32PM +0300, Maxim Dounin wrote:
> 
> > Hello!
> > 
> > On Fri, Mar 20, 2009 at 12:42:47AM +0200, Андрей Василишин wrote:
> > 
> > > Maxim Dounin пишет:
> > >> Hello!
> > >>
> > >> On Thu, Mar 19, 2009 at 04:40:39PM +0200, Андрей Василишин wrote:
> > >>
> > >>   
> > >>>> Как сделать так, чтобы при превышении limit_conn one  1; клиенту   
> > >>>> отдавалась /503.html, сейчас я так понял отдается 404 (Firefox не   
> > >>>> может найти файл)?
> > >>>>       
> > >>> Игорь, все-таки можно что-нибудь придумать или нет?
> > >>>     
> > >>
> > >> Пропробуйте 
> > >>
> > >>     location /503.html {
> > >>         add_header Content-Disposition "";
> > >>         ...
> > >>     }
> > >>
> > >> Это должно убрать из ответа заголовок Content-Disposition, который  
> > >> прилетает из скрипта отдающего X-Accel-Redirect, и судя по всему 
> > >> вызывает подобную реакцию FireFox'а.
> > >>
> > >> Maxim Dounin
> > >>   
> > > *syntax: *add_header */название значение/*
> > > *default: *нет
> > > *context: *http, server, location
> > >
> > > Директива добавляет строку в заголовке ответа при условии, что код  
> > > ответа равен 200, 204, 301, 302 или 304. В значении можно использовать  
> > > переменные.
> > >
> > >
> > > Тут ответ ведь 503
> > 
> > Да, я ошибся.  Кроме того, значение Content-Disposition 
> > вышеуказанная конструкция не очистит даже если сработает - 
> > add_header умеет чистить только Cache-Control и Last-Modified.
> > 
> > Workaround - попробовать возвращать Content-Disposition в другом 
> > заголовке, и добавлять через add_header если всё хорошо.  Как-то 
> > так:
> > 
> >     location /files/ {
> >         internal;
> >         add_header Content-Disposition $upstream_http_x_content_disposition;
> >         ...
> >     }
> > 
> > Но вообще наверное надо с этим что-то сделать кардинально.
> 
> Я думаю, нужно чистить Content-Disposition прямо в
> ngx_http_special_response_handler()

Вероятно.  Я даже почти уверен что это ничего не сломает.

Не совсем понятно что делать с другими заголовками в подобной 
ситуации.  В частности, из upstream'а сейчас могут прилететь при 
X-Accel-Redirect:

Content-Type
Set-Cookie
Content-Disposition
Cache-Control
Expires
Accept-Ranges

Из них сейчас чистится/переставляются Content-Type и 
Accept-Ranges.  Помимо Content-Disposition остаются ещё 
Set-Cookie, Cache-Control, Expires.  И что-то мне подсказывает что 
как минимум с последними двумя можно получить неприятностей.

Maxim Dounin





More information about the nginx-ru mailing list