Re: Теперь нельзя выставлять тип контента!

Maxim Dounin mdounin at mdounin.ru
Fri Aug 8 14:02:24 UTC 2014


Hello!

On Thu, Aug 07, 2014 at 11:49:01AM -0400, rand257 wrote:

> Доброго времени суток!
> 
> Извиняюсь за поднятие столь старой темы, но она полностью соответствует
> моему вопросу.
> 
> Итак:
> Имеется nginx, php-fpm и сайт файлохранилища, в котором для выдачи
> статических файлов используется заголовок X-Accel-Redirect в отдельный
> специальный локейшен. В этом локейшене выставлен post_action на вызов
> php-скрипта, подсчитывающий статистику по трафику с выполненного запроса и
> количеству завершенных/незавершенных скачиваний файлов. После обновления
> nginx с некоей доисторической версии на современную 1.6.1 скрипт статистики
> более не вызывается, в логах имеется упоминавшийся здесь алерт "header
> already sent while reading response".

Это выглядит как ошибка, post_action не должен приводить к 
срабатыванию этой проверки, т.к. заголовок на самом деле второй 
раз не посылает.

Патч:

--- a/src/http/ngx_http_core_module.c
+++ b/src/http/ngx_http_core_module.c
@@ -1972,7 +1972,7 @@ ngx_http_send_response(ngx_http_request_
 ngx_int_t
 ngx_http_send_header(ngx_http_request_t *r)
 {
-    if (r->header_sent) {
+    if (r->header_sent && !r->post_action) {
         ngx_log_error(NGX_LOG_ALERT, r->connection->log, 0,
                       "header already sent");
         return NGX_ERROR;

-- 
Maxim Dounin
http://nginx.org/



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