mod_fcgid + php + nginx 0.7.64 = upstream prematurely closed connection while reading response header from upstream

Одинцов Павел pavel.odintsov на googlemail.com
Вт Янв 26 03:58:20 MSK 2010


Доброй ночи!

Столкнулись с такой проблемой: nginx настроен на проксирование Apache,
который выполняет PHP скрипты посредством mod_fcgid. При этом, у
бэкэнда очень часто происходит "мягкий" реалоад апачи посредством
/etc/init.d/apache reload. Проблема в том, что этот реалоад (как я
понимаю, по вине mod_fcgid ) не совсем корректно, что приводит к куче
502х отбоев со следующей ошибкой в логах: upstream prematurely closed
connection while reading response header from upstream

При активированном дебаг логе выходит следующее:
2010/01/26 00:26:00 [debug] 689#0: *8 malloc: 0000000001F18FB0:4096
2010/01/26 00:26:00 [debug] 689#0: *8 recv: fd:21 0 of 4096 ### тут
очень странно такое поведение
2010/01/26 00:26:00 [error] 689#0: *8 upstream prematurely closed
connection while reading response header from upstream, client:
88.198.36.53, server: test1.ru, request: "GET / HTTP/1.0", upstream:
"http://88.198.35.235:8080/", host: "test1.ru"
2010/01/26 00:26:00 [debug] 689#0: *8 http next upstream, 2
2010/01/26 00:26:00 [debug] 689#0: *8 free rr peer 1 4
2010/01/26 00:26:00 [debug] 689#0: *8 finalize http upstream request: 502
2010/01/26 00:26:00 [debug] 689#0: *8 finalize http proxy request
2010/01/26 00:26:00 [debug] 689#0: *8 free rr peer 0 0
2010/01/26 00:26:00 [debug] 689#0: *8 close http upstream connection: 21
2010/01/26 00:26:00 [debug] 689#0: *8 event timer del: 21: 1264454817346
2010/01/26 00:26:00 [debug] 689#0: *8 http finalize request: 502, "/?" 1
2010/01/26 00:26:00 [debug] 689#0: *8 http special response: 502, "/?"
2010/01/26 00:26:00 [debug] 689#0: *8 http set discard body
2010/01/26 00:26:00 [debug] 689#0: *8 HTTP/1.1 502 Bad Gateway
Server: nginx/0.7.64
Date: Mon, 25 Jan 2010 21:26:00 GMT
Content-Type: text/html
Content-Length: 173
Connection: close

Как я понял по исходникам, Апача принимает соединение, Nginx его также
устанавливает успешно, но при чтении Nginx ом хидера, считывается нуль
байт и на после этого клиент получает 502. Интересует возможность
настройки Nginx (либо его пропатчивания) чтобы он делал вторую попытку
коннекта, если первый раз получил пустой хидер.

-- 
С уважением, Одинцов Павел


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