Back to questions
Junior — Middle
87
Каким образом можно реализовать работу с несколькими потоками или процессами в Node.js для повышения производительности?
Answer from AI
sobes.tech AI
В Node.js для работы с несколькими потоками или процессами можно использовать несколько подходов:
- Модуль
cluster— позволяет создавать несколько процессов-воркеров, которые могут обрабатывать запросы параллельно, используя все ядра CPU. Каждый воркер — отдельный процесс с собственным event loop.
const cluster = require('cluster');
const http = require('http');
const numCPUs = require('os').cpus().length;
if (cluster.isMaster) {
for (let i = 0; i < numCPUs; i++) {
cluster.fork();
}
} else {
http.createServer((req, res) => {
res.writeHead(200);
res.end('Hello from worker ' + process.pid);
}).listen(8000);
}
- Worker Threads (
worker_threads) — позволяют создавать потоки внутри одного процесса, которые могут выполнять CPU-интенсивные задачи параллельно, не блокируя основной event loop.
const { Worker } = require('worker_threads');
const worker = new Worker(`
const { parentPort } = require('worker_threads');
parentPort.postMessage('Hello from worker thread');
`, { eval: true });
worker.on('message', message => console.log(message));
- Внешние процессы (
child_process) — можно запускать отдельные процессы и обмениваться с ними данными через IPC.
Выбор зависит от задачи: для масштабирования серверов лучше cluster, для вычислений — worker_threads.