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

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

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

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

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

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

3 ответов

14 просмотров

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

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

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

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

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта