Sobes.tech
Back to questions
Junior — Middle
87

Каким образом можно реализовать работу с несколькими потоками или процессами в Node.js для повышения производительности?

Answer from AI

sobes.tech AI

В Node.js для работы с несколькими потоками или процессами можно использовать несколько подходов:

  1. Модуль 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);
}
  1. 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));
  1. Внешние процессы (child_process) — можно запускать отдельные процессы и обмениваться с ними данными через IPC.

Выбор зависит от задачи: для масштабирования серверов лучше cluster, для вычислений — worker_threads.