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

А можно нубский вопрос. Вот я ноду не сильно давно

изучаю. И задался таким вопросам, нода однопоточна хоть и асинхронна.
Но вот в чем проблема, сделал я приложение и оно в ответ на запрос делает очень сложные вычисления . Вот пришел первый хост и послал запрос,, и запрос его выполняется и производятся вычисления, и тут же приходит второй хост и тоже делает запрос. Я так полагаю его запрос не будет обработан сразу так как в event loop уже очередь из событий и пока первый запрос не посчитается то нода ко второму запросу не приступит? или там по другому будет?

3 ответов

14 просмотров

Что ты имеешь введу под вычислениями? Просто синхронный код, который долго выполняется?

Если задача жрет процессорное время и при этом синхронна, то евентлуп заблокируется. Есть несколько подходов для решения задачи, вычилять порционно, либо запускать такие задачи как отдельные процессы или треды, используя либы.

Да, пока не посчитает первый запрос, второй запрос не обработается. Вариант 1: используй Worker Threads (если сервак >1cpu и такие реквесты редкие и просто не хочется чтобы другие ждали) Вариант 2: масштабирующийся микросервис/функция под тяжелые расчёты Первый вариант это если у тебя классический хостинг, >1цпу и не очень большие нагрузки, ну а второй это уже серьёзный вариант, облако и автоскейлинг...

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

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

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
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
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
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Карта сайта