Вопрос программистам

интернет компьютеры программирование Linux java

Какую технологию лучше использовать при написании сокет-сервера, который требует огромного числа одновременных подключений (до 100.000 на одной машине), но при этом бОльшую часть времени проводит в ожидании? Кол-во одновременных запросов вряд ли превысит 5.000-10.000.

Можно ли рассчитывать на NPTL или лучше писать с NIO? Другие предложения?
У кого есть опыт?

Примечание:
Ясно, раз event-driven, тогда буду писать с netty.
Ответы:
Проще писать событийно-ориентированное приложение. Для этого есть системные вызовы epoll, select. При таком программирование достигается максимальная производительность.
Может быть, лучше использовать готовые решения ( (x)inetd ) ?
если под "положиться на NPTL" имеется в виду лобовой подход "1 соединение = 1 нить", то 100000 тредов не выдержит ни одна машина: на один только стек, пусть даже по 64к, уйдёт 6 гигов, а есть ещё другие ограничения. ну и нерационально оно, когда большинство коннектов будет простаивать.
поэтому только event-driven подход - см. libevent


14 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.