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