fastcgi keep-alive

Alexander Dolgarev a.dolgarev at gmail.com
Sun Apr 12 17:27:02 MSD 2009


ab при указании ключа -k шлет заголовок Connection: Keep-Alive, но при
этом версия HTTP/1.0. nginx если отдает статический файл, то не
закрывает соединение, при отдаче ответа с fastcgi соединение
закрывается. Происходит это скорее всего потому, что Content-Length
при отдаче статического файла известен, а при динамически создаваемом
ответе - нет, в случае HTTP/1.1 ответ идет чанками, в случае HTTP/1.0
чанки не поддерживаются, потому ответ идет без Content-Length с
закрытием соединения.

Попробовал httperf, довольно хорошая штука, поддерживает HTTP/1.1, но
при использовании большого количества соединений отжирает МНОГО CPU
(полностью одно ядро), потому о тестировании сервера говорить не
приходится.

Вкратце моя задача: правильно настроить связку nginx-fastcgi для
увеличения количества ответов в секунду (сейчас fastcgi-сервер - это
просто выдача "Hellow World" на клиента, за основу взято
http://www.fastcgi.com/devkit/examples/threaded.c), при этом клиентов
на сервер около 1000, т.е. 1000 соединений, каждый клиент постоянно
шлет запросы.

С настройкой fastcgi свои проблемы, во-первых, непонятно сколько
потоков должно быть у fastcgi-сервера при нескольких тыс. запросов в
секунду к nginx, сейчас пробую 200, но это пальцем в небо если не
сказать хуже. Во-вторых, странные результаты тестов:
1) при использовании unix domain sockets ab выдает картину:

$ ab -c 1000 -n 100000 http://localhost/
Concurrency Level:      1000
Time taken for tests:   19.685463 seconds
Complete requests:      100000
Failed requests:        95022
   (Connect: 0, Length: 95022, Exceptions: 0)
Write errors:           0
Non-2xx responses:      755
Keep-Alive requests:    755
Total transferred:      33916538 bytes
HTML transferred:       21683403 bytes
Requests per second:    5079.89 [#/sec] (mean)
Time per request:       196.855 [ms] (mean)
Time per request:       0.197 [ms] (mean, across all concurrent requests)
Transfer rate:          1682.51 [Kbytes/sec] received

Странность что за Failed requests: 95022, при том что Non-2xx
responses: 755. При увеличении количества потоков картина немного
улучшается, но кардинально не изменяется.
При этом в логах постоянно появляется ошибка

[error] 15444#0: *1341999 connect() to unix:/tmp/a.out failed (11: )
while connecting to upstream, client: 127.0.0.1, server: localhost,
request: "GET / HTTP/1.0", upstream: "fastcgi://unix:/tmp/a.out:",
host: "localhost"
Я так понимаю это connection refused (надо увеличить backlog? где в
linux устанавливается его предел? по умолчанию предел 128 или 2048?).
Backlog как минимум 128. Вообще возможно чтобы nginx не бомбил сервер
соединениями, а имел какой-нибудь пул соединений?

2) при использовании TCP сокетов все замирает, при этом ни nginx ни
fcgi-сервер абсолютно не нагружены, но появляется следующая ошибка:

[error] 17291#0: *2159 upstream timed out (110: ) while connecting to
upstream, client: 127.0.0.1, server: localhost, request: "GET /
HTTP/1.0", upstream: "fastcgi://127.0.0.1:9000", host: "localhost"

Заканчивается все тем, что ab выдает:
apr_socket_recv: Connection timed out (110)


Итого, основной вопрос: как правильно настроить nginx и fastcgi-сервер
для максимальной производительности (количество ответов в секунду) при
условии большого количества клиентов (соединений, 1000) и большого
количества запросов по каждому соединению.


2009/4/12 Борис Долгов <boris at dolgov.name>:
> ab -k :)
>
> 12 апреля 2009 г. 12:46 пользователь Alexander Dolgarev
> <a.dolgarev at gmail.com> написал:
>>
>> хм, действительно, ab посылает HTTP/1.0, не посоветуете другую тулзу
>> для проверки производительности?
>>
>> 2009/4/12 Maxim Dounin <mdounin at mdounin.ru>:
>> > Hello!
>> >
>> > On Sun, Apr 12, 2009 at 01:49:09AM +0300, Alexander Dolgarev wrote:
>> >
>> >> возник вопрос относительно модуля ngx_http_fastcgi_module, вопрос
>> >> собственно простой: почему не работает keep-alive при использовании
>> >> FastCGI (nginx посылает Conncetion: close)?
>> >>
>> >> Например:
>> >>         location / {
>> >>             root   html;
>> >>             index  index.html index.htm;
>> >>
>> >>             fastcgi_pass   unix:/tmp/a.out;
>> >>
>> >>             fastcgi_param  QUERY_STRING     $query_string;
>> >>             fastcgi_param  REQUEST_METHOD   $request_method;
>> >>             fastcgi_param  CONTENT_TYPE     $content_type;
>> >>             fastcgi_param  CONTENT_LENGTH   $content_length;
>> >>         }
>> >>
>> >> Если закомментировать fastcgi_pass, то keep-alive работает.
>> >
>> > Потому что в HTTP/1.0 нет другого способа передать ответ без
>> > Content-Length.  При использовании HTTP/1.1 - не отключается.
>> >
>> > Maxim Dounin
>> >
>> >
>
>
>
> --
> С уважением, Борис Долгов.
> icq 77556665
> e-mail boris at dolgov.name
>


More information about the nginx-ru mailing list