Re: nginx и http несовместимый сервер.

Maxim Dounin mdounin на mdounin.ru
Пн Фев 28 19:17:24 MSK 2011


Hello!

On Mon, Feb 28, 2011 at 05:58:52PM +0300, Ипполитов Игорь wrote:

> Есть сервер приложений, который игнорирует заголовки Connection: close; и
> версию запроса (1.0 или 1.1): независимо ни от чего, сервер держит
> соединение с клиентом открытым.
> Есть нгинкс, который проксирует соединение до этого сервера.
> Проблема:
> Нгинкс проксирует запрос от клиента к серверу приложений, получает ответ с
> заголовком Content-Length и далее нужное количество байт в теле ответа.
> Если буферизация ответов апстрима включена (proxy_buffering on;), то нгинкс
> отдаёт клиенту заголовки ответа, без тела (но с content-length), а в лог
> пишет, что
> *upstream timed out (110: Connection timed out) while reading upstream*
> Если буферизация ответов апстрима выключена (proxy_buffering off;), то ответ
> нормально отдаётся клиенту. Но при этом ломается кэширование (кэширование не
> работает без буферизации).
> 
> Мне удалось найти аналогичную проблему у другого человека:
> http://www.ruby-forum.com/topic/166377 . Более того, по ссылке в беседе
> участвует и некий Денис Латыпов, который даже предлагает патч.
> 
> Вопросы: патч предложенный Денисом не принят в нгинкс? Патч не имеет
> отношения к моей проблеме? Что мне можно сделать, кроме изменений в сервер
> приложений?

Это был не Денис, и нет, упомянутые патчи пока не включены в 
nginx.

> P.S.
> Я прекрасно понимаю, что с http-несовместимым сервером нгинкс работать и не
> должен, но почему тогда при отключении буферизации ответа всё работает
> хорошо?

Потому что при отключении буферизации nginx не буферизирует ответ, 
а сразу отправляет его клиенту.  А при включении - буферизирует, 
обнаруживает ошибку, и закрывает соединение (так и не отправив ту 
часть ответа, которая ещё лежит в буфере).

Maxim Dounin



Подробная информация о списке рассылки nginx-ru