[Moscow.pm] Moscow.pm party: доклад-реквесты
Анатолий Гришаев
0body0 на rambler.ru
Сб Ноя 23 09:28:55 PST 2013
А сколько можно выжать из перлового http сервера запросов в секунду на ядро?
Я в рассылке видел 1к для hello-world, но мне кажется это мало.
В текущем варианте у меня получается 5к http на ядро в конфигурации
nginx +perl-fcgi.
Но sieve в выдает нагрузку 100% по CPU и результаты сильно зависят от
запуска к запуску.
Вопрос No2: чем лучше обстреливать?
>
> Пример, который я имел в виду:
> Писал я UDP сервер. Мне нужно было проверить предельную нагрузку. Я
> сделал клиент, который заваливал интерфейс UDP пакетами.
> Написал асинхронный udp сервер на perl/EV. мало пакетов при 100% CPU.
> Написал аналогичный сервер на C/libev. Прирост 10-20%, 100% CPU.
> Написал синхронный сервер на Pure Perl. Прирост 400%.
>
> Ситуация оказалась довольно простая: в синхронном варианте всё, что
> делает сервер - это вызывает в цикле recv, тогда как в асинхронном
> почти на каждый пришедший пакет вызывается on_read watcher.
>
> Решилось довольно просто.
> SO_RECVBUF был поднят до нескольких мегабайт, а после прочтения
> пакетов из сокета следующий on_read ставился не сразу, а через 0.0001s.
> После этого изменения на каждый on_read мы вычитывали не 1-2 пакета,
> а, в зависимости от значения таймера, от 10 до 1000 пакетов за 1 раз.
>
> соответственно оверхед от ev был сведен к процентам и
> производительность получилось почти такая, как у синхронного варианта.
>
> PS: Perl/EV на 1 core при 100% загрузке CPU в пределе может обработать
> около 450-500k udp pkt/s
>
>
>
>
----------- следущая часть -----------
Вложение в формате HTML было извлечено…
URL: <http://mail.pm.org/pipermail/moscow-pm/attachments/20131123/e7b55651/attachment.html>
Подробная информация о списке рассылки Moscow-pm