"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Mise à l'échelle de Node.js avec le module Cluster

Mise à l'échelle de Node.js avec le module Cluster

Publié le 2024-11-04
Parcourir:575

Scaling Node.js with the Cluster Module

Le module Cluster permet à Node.js d'exploiter les systèmes multicœurs, améliorant ainsi les performances des applications. Voyons comment l'utiliser efficacement.

Pourquoi Cluster ?

  1. Utiliser tous les cœurs de processeur
  2. Améliorer la réactivité de l'application
  3. Augmentez la fiabilité grâce à la redondance des employés

Utilisation de base

const cluster = require('cluster');
const http = require('http');
const numCPUs = require('os').cpus().length;

if (cluster.isMaster) {
  console.log(`Master ${process.pid} is running`);

  // Fork workers
  for (let i = 0; i  {
    console.log(`Worker ${worker.process.pid} died`);
  });
} else {
  // Workers can share any TCP connection
  http.createServer((req, res) => {
    res.writeHead(200);
    res.end('Hello World\n');
  }).listen(8000);

  console.log(`Worker ${process.pid} started`);
}

Équilibrage de charge

Node.js gère automatiquement l'équilibrage de charge à l'aide d'une approche circulaire.

Communication inter-processus (IPC)

if (cluster.isMaster) {
  const worker = cluster.fork();
  worker.send('Hi there');
} else {
  process.on('message', (msg) => {
    console.log('Message from master:', msg);
  });
}

Redémarrages sans temps d'arrêt

if (cluster.isMaster) {
  cluster.on('exit', (worker, code, signal) => {
    if (!worker.exitedAfterDisconnect) {
      console.log('Worker crashed. Starting a new worker');
      cluster.fork();
    }
  });

  process.on('SIGUSR2', () => {
    const workers = Object.values(cluster.workers);
    const restartWorker = (workerIndex) => {
      const worker = workers[workerIndex];
      if (!worker) return;

      worker.on('exit', () => {
        if (!worker.exitedAfterDisconnect) return;
        console.log(`Exited process ${worker.process.pid}`);
        cluster.fork().on('listening', () => {
          restartWorker(workerIndex   1);
        });
      });

      worker.disconnect();
    };

    restartWorker(0);
  });
}

Meilleures pratiques

  1. Utilisez Worker_threads pour les tâches gourmandes en CPU
  2. Mettre en œuvre une gestion appropriée des erreurs chez les travailleurs
  3. Surveiller la santé des travailleurs et redémarrer si nécessaire
  4. Utiliser un gestionnaire de processus comme PM2 pour la production

Les pièges à éviter

  1. Le serveur de partage gère explicitement (Node.js le fait automatiquement)
  2. Une utilisation excessive de l'IPC (peut devenir un goulot d'étranglement)
  3. Négliger de gérer les accidents des travailleurs

Le module Cluster est puissant pour la mise à l'échelle horizontale, mais à utiliser judicieusement. Créez toujours un profil pour vous assurer qu'il répond à vos besoins spécifiques en matière de performances.

Acclamations?

Déclaration de sortie Cet article est reproduit sur : https://dev.to/sarvabharan/scaling-nodejs-with-the-cluster-module-5dm9?1 En cas de violation, veuillez contacter [email protected] pour le supprimer.
Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3