Node.js часто называют "однопоточным", хотя в реальности он многопоточный. Возникает вопрос: откуда такое название? Ответ на этот вопрос связан с особенностью обработки входящих запросов и встроенной асинхронной моделью в Node.js.
Node.js построен на базе движка V8, который в основном предназначен для работы в однопоточной среде. Однако Node.js расширяет возможности V8, добавляя механизмы работы с событиями и асинхронным вводом-выводом. Это позволяет Node.js эффективно обрабатывать множество одновременных запросов без использования большого количества потоков.
Основная идея Node.js состоит в том, чтобы использовать несколько потоков для обработки ввода-вывода и один поток (называемый "event loop") для выполнения JavaScript кода. Подход, известный как "однопоточная событийная модель", позволяет Node.js обрабатывать множество запросов практически параллельно, без блокировки потока выполнения.
Когда Node.js получает запрос, он создает отдельный поток для обработки его ввода-вывода (например, чтения данных из файловой системы или получения данных от базы данных). После завершения операции ввода-вывода, результат возвращается в главный поток (event loop) для дальнейшей обработки. В то время, как главный поток ожидает завершения операции ввода-вывода, другие запросы могут быть обработаны в отдельных потоках.
Таким образом, Node.js позволяет эффективно использовать ресурсы процессора и обрабатывать множество одновременных запросов без блокировки потока выполнения и без создания множества потоков, как это делается в традиционных многопоточных моделях.
Но несмотря на то, что Node.js использует многопоточность в своей работе, главный поток (event loop) всегда есть только один и он выполняет JavaScript код последовательно. Именно поэтому Node.js всё равно часто называют "однопоточным".
В заключение, Node.js является многопоточной платформой, которая позволяет эффективно обрабатывать множество запросов, однако главный поток (event loop) выполняет код JavaScript последовательно, что приводит к названию "однопоточный".