170 похожих чатов

Привет. Начал изучать джаву, решил сделать простое REST API, которое

в основном общается с базой и возвращает ответы оттуда в нужном формате. Не могу никак нагуглить как в джаве делать приложения такого рода максимально эффективными, в гугле все предлагают создавать новые треды или использовать пулл тредов, но это не решает проблему эффективного использования железа для этой задачи.

Простой пример - представим что наша БД это микросервис который отвечает 1 секунду (просто для наглядности). Мы принимаем запросы, в пулл из 100 тредов, берем запрос к API, делаем запрос к БД, ждем ответа ничего не делая в этом треде и засыпая, а потом делаем что-то ещё и отдаём результат.

И вот мы приняли 100 запросов, треды спят дожидаясь ответа, и 101 запрос мы уже не обрабатываем до того момента, пока один из тредов не освободится. При этом, мы не делаем вообще ничего полезного, хотя могли бы пока ждем ответа от БД, сделать другую работу, не зависящую от данных из БД. Таким образом мы завязаны на скорость IO, на ответы БД, на ответы других бэкэндов и сторонних API и не делаем ничего дожидаясь от них ответов. Это очень не эффективно.

Как решают эти задачи в java? В nodejs например, есть event loop, который позволяет во время ожидания выполнять другую работу в одном и том же треде. В php есть генераторы (yield) на которых строят свои event loop (reactPHP, AMPhp) и таким образом тоже делают полезную работу пока ожидают ответа. А что делают в java?

3 ответов

12 просмотров

почитай про селекторы

> А что делают в java не парятся и расставляют спринговые аннотации А если серьезно, то используют какой-нибудь фреймворк, в котором нетти под копотом, в котором тот же самый евент луп. (с БД проблема никуда не делась)

Vlad- Автор вопроса
Костя
почитай про селекторы

Про какие селекторы?

Похожие вопросы

Обсуждают сегодня

Всем привет! Имеется функция: function IsValidChar(ch: UTF8Char): Boolean; var i: Integer; ValidChars: AnsiString; begin ValidChars := 'abcdefghijklmnopqrstuvwxyzABCDE...
Евгений
44
И никого не интересует какие пакеты кто использует. ((% Заходишь на сайт симфони и видишь поддержку Украины - по законам РФ это ж экстремизм. Только никто не отказывается от с...
Am Ambrion
11
лучше скажите, причём тут паскаль?
Alexey Kulakov
36
Чтобы перехватить все нажимания буков на форме, надо хук ставить? Пробовал на форме ОнКейДаун, оно ловит клаву если фокус не на компоненте с вводом текста
Serjone
15
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
7
Народ! Впервые клиенту пришло письмо от РКН, у вас, дескать, есть яндекс метрика, а нигде не написано, что вы ее юзаете. Никто не сталкивался?
Sasha Beep
14
Всем привет! вывожу на общей стр дочерние ресурсыв каждом ресурсе галерея, и первая фотка должна выводиться на общей [!DocLister? &prepare=photo !]
Alekso
12
Я правильно понимаю что нет способов получить список ожидающих заявок на вступление в группу с помощью бота из mtproto?
Шамиль Прилов
7
А можно вопрос? Мне сегодня сказали что у меня функция (которая просто заполняет массив значениями) не правильная void Full(double * arr, int n) { for (int i = 0; i < n; i...
† C E †
7
Добрый вечер. Хочу чтобы у меня в классе поле было функцией, которая возвращает строку. Делаю так: interface ... TGetOutPath = function : String of object; ... protec...
Kirill Filippenok
12
Карта сайта