У меня есть маршрут в моем приложении Node.js, которому требуется около 10 секунд для ответа на каждый запрос.
router.get("/", async (req, res, next) => {
console.info("Service health request.", req.ip, new Date());
let response = { success: true, message: "Service is running!!" };
await wait(10000);
return res.json(response);
});
const wait = (milliseconds) => {
return new Promise(resolve => setTimeout(resolve, milliseconds));
}
Когда я делаю несколько запросов к этому маршруту одновременно, я замечаю, что каждый запрос выполняется последовательно, при этом первый запрос занимает 10 секунд, второй запрос занимает 20 секунд, третий запрос занимает 30 секунд и так далее.
Что интересно, когда я одновременно запрашиваю другой маршрут в своем приложении, он обрабатывается без задержки, что наводит меня на мысль, что проблема связана с рассматриваемым маршрутом.
router.get("/status", async (req, res, next) => {
console.info("Any other route request.");
let response = { success: true, data: {} };
await wait(10000);
return res.json(response);
});
Мне интересно, почему мои запросы к этому конкретному маршруту обрабатываются последовательно, а не одновременно. Хотя я знаю, что обратные вызовы и асинхронное программирование могут помочь мне добиться параллельной обработки. Я читал о цикле событий Node.js и его однопоточной природе, но я не уверен, как это связано с моей проблемой.
Кто-нибудь может объяснить, почему мои запросы к этому конкретному маршруту обрабатываются последовательно? В дополнение к моей основной проблеме мне любопытно, создает ли Node.js отдельный цикл событий или стек вызовов для каждого маршрута в приложении?
Я предполагаю, что ваши тесты выполняются в браузере. Если да, то поведение не имеет ничего общего с Node.js.
Браузер распознает, что запросы относятся к одному и тому же URL-адресу, и отправит их по одному, поскольку сервер может ответить заголовками управления кешем, что позволит ему повторно использовать ответ на первый запрос в качестве ответа для последующих.
Спасибо, @Quentin, я не знал об этом поведении, когда проверял его в своем браузере. Однако, когда я использую curl или другие HTTP-клиенты для выполнения запроса, он меня не блокирует.