[feature request] X-Sendfile
Sergey Serov
mpa at corg.net
Mon Apr 24 21:01:37 MSD 2006
On Monday 24 April 2006 15:24, Igor Sysoev wrote:
> On Mon, 24 Apr 2006, Sergey Serov wrote:
> > On Monday 24 April 2006 14:19, Igor Sysoev wrote:
> >> On Mon, 24 Apr 2006, Sergey Serov wrote:
> >>>> Прилагаемый патч, превращает POST в GET для внтутреннего редиректа и,
> >>>> кроме того, позволяет вместо
> >>>
> >>> Патч применил, теперь все работает.
> >>>
> >>>> if ($request_method != "POST") {
> >>>>
> >>>> писать
> >>>>
> >>>> limit_except POST {
> >>>> deny all;
> >>>> }
> >>>
> >>> Но deny вернет 403 клиенту, а 405 здесь будет более правильно, если не
> >>> память мне не изменяет, то Апач так и делает в аналогичной директиве.
> >>
> >> Можно так:
> >>
> >> limit_except POST {
> >> deny all;
> >> }
> >>
> >> error_page 403 =405 /error_page.html;
> >
> > Все равно не совсем корректно, тогда невозможно будет правильный статус
> > 403 послать. К тому же будет несколько лишних дисковых syscall на
> > обработку /error_page.html. При незагруженном процессоре и перегруженном
> > диске в какой-то момент это может стать критичным.
>
> Если этот error_page стоит только внтутри location, уходящего на fastcgi,
> то там других 403 появится не откуда.
Есть откуда, я шлю 403 когда юзеру или подсети действительно запрещен доступ.
А также и другие статусы при соотв. ситуациях. В логах потом гораздо проще
анализировать что происходит.
Кстати, насчет статусов. Заметил у nginx что если fastcgi отваливается по
таймауту, то в логе $status пишется как 0. При этом юзеру сообщается
правильный статус 504 (по помню точто, но Gateway Timeout сообщение там
было). При анализе логов это будет очень мешать.
>
> А сисколов можно избежать так:
>
> error_page 403 = /405;
>
> location = /405 {
> return 405;
> }
>
> limit_except работает немного быстрее, чем
> if ($request_method != "POST"), но разница не велика.
Хорошо, я попробую. Спасибо!
More information about the nginx-ru
mailing list