Re: Сокет не закрывается после отправки тела
Maxim Dounin
mdounin на mdounin.ru
Пт Июн 15 10:05:01 UTC 2018
Hello!
On Thu, Jun 14, 2018 at 10:48:34AM -0400, eustas wrote:
> 1) common sense - иначе вышестоящий фильтр не узнает закончилась ли
> отправка
Фильтры - пропускают через себя данные, которые им передают.
Отправка заканчивается тогда, когда a) источник данных всё
передал, и б) не осталось буферизированных где-либо данных.
Ни о каком NGX_DONE тут с точки зрения common sense речи не идёт
как минимум по двум причинам:
- нет семантических отличий от стандартной пары NGX_OK / NGX_AGAIN;
- информации недостаточно для выражения состояния "не осталось
буферизированных где-либо данных".
Но вообще, common sense - плохой источник знаний об API.
> 2) common practice -
> https://github.com/nginx/nginx/blob/master/src/http/modules/ngx_http_gzip_filter_module.c#L621
> и ещё 10 модулей возвращают NGX_DONE
По сслыке - использование кода NGX_DONE во внутренней функции
ngx_http_gzip_filter_buffer(), не более того.
Про "ещё 10 модулей" - верю (считать лень), но, боюсь, ни одного
фильтра среди них вы не найдёте.
> 3) документация - "NGX_DONE — Operation complete or continued elsewhere.
> Also used as an alternative success code" и более никаких объяснений, в
> каких случаях фильтр может его возвращать.
Потому a) речь идёт об описании семантики кода, а не о его
использовании в конкретных местах, и б) фильтр никогда не может
возвращать NGX_DONE.
> В
> http://nginx.org/en/docs/dev/development_guide.html#http_building_filter_modules
> описано только 2 случая - возврат NGX_ERROR и возврат значения полученного
> от следующего фильтра. Если следовать этому, то из каких соображений можно
> было бы вернуть NGX_OK?
Development guide - это всё-таки guide, а не reference. Он
показывает, как делать стандартные вещи, но не заменяет чтение
кода там, где вы пытаетесь выйти за пределы явно описанного.
В общем, выпиливайте NGX_DONE. Фильтры его возвращать не должны,
и если вдруг возвращают - последствия непредсказуемы. Странно,
что у вас раньше от этого ничего не ломалось - должны были быть
серьёзные проблемы из-за некорректной финализации, если она
случалась с NGX_DONE.
--
Maxim Dounin
http://mdounin.ru/
Подробная информация о списке рассылки nginx-ru