Maison interface Web js tutoriel Une introduction détaillée au module multi-processus Cluster dans Node.js et comment l'utiliser

Une introduction détaillée au module multi-processus Cluster dans Node.js et comment l'utiliser

May 27, 2017 am 10:44 AM

Comme nous le savons tous, Node.js est monothread et un seul processus Node.js ne peut pas utiliser pleinement plusieurs cœurs. À partir de la version 0.6.0, Node.js a ajouté un module de cluster, qui facilite l'utilisation complète des machines multicœurs lors du développement de services Web avec Node.js. Cet article vous présente principalement les informations pertinentes sur le module multi-processus Cluster dans Node.js. Les amis qui en ont besoin peuvent se référer à

Avant-propos

.

Nous savons tous que la plus grande fonctionnalité de nodejs est un processus unique, un fonctionnement non bloquant et un fonctionnement asynchrone piloté par les événements. Ces fonctionnalités de Nodejs peuvent très bien résoudre certains problèmes. Par exemple, dans le développement de serveurs, le traitement simultané des requêtes est un gros problème et le blocage des fonctions entraînera un gaspillage de ressources et un retard. Grâce à l'enregistrement des événements et aux fonctions asynchrones, les développeurs peuvent améliorer l'utilisation des ressources et les performances seront améliorées. Étant donné que Node.js adopte le mode monoprocessus et monothread, dans l'environnement actuel où le matériel multicœur est populaire, comment Nodejs, qui offre d'excellentes performances monocœur, peut-il tirer parti des processeurs multicœurs ? Le fondateur Ryan Dahl recommande d'exécuter plusieurs processus Nodejs et d'utiliser un mécanisme de communication pour coordonner les tâches. Actuellement, de nombreux modules tiers de prise en charge multi-processus Node.js ont été publiés, et les versions 0.6.x et supérieures de NodeJS fournissent un module de cluster qui permet la création d'un groupe de processus qui "partagent le même socket" pour partager la charge. pression. .

Cet article s'appuie sur le module cluster pour décrire la programmation Node.js sous CPU multi-core.

Introduction au module Cluster

Le module cluster fourni par nodejs est actuellement au stade expérimental On peut le voir dans le document officiel de la v0. .10.7 Les informations de version du module sont les suivantes :


Stability: 1 - Experimental
Copier après la connexion

Concernant la fonction de ce module, le document source décrit ceci "Une seule instance de Node s'exécute dans un seul thread. Pour tirer parti des systèmes multicœurs, l'utilisateur souhaitera parfois lancer un cluster de processus Node pour gérer la charge. " Cela signifie : les exemples de nœuds s'exécutent en mode monoprocessus, et parfois afin d'en tirer pleinement parti. des ressources des systèmes multicœurs, les utilisateurs doivent exécuter un cluster de processus Node pour partager la charge.

Introduction à l'utilisation du cluster

Tout d'abord, publiez un exemple de code d'application de ce module, puis effectuez une analyse détaillée. Le code est le suivant. suit :


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

if (cluster.isMaster) {
 require('os').cpus().forEach(function(){
 cluster.fork();
 });
 cluster.on('exit', function(worker, code, signal) {
 console.log('worker ' + worker.process.pid + ' died');
 });
 cluster.on('listening', function(worker, address) { 
 console.log("A worker with #"+worker.id+" is now connected to " +
  address.address +
 ":" + address.port); 
 }); 
} else {
 http.createServer(function(req, res) {
 res.writeHead(200);
 res.end("hello world\n");
 console.log('Worker #' + cluster.worker.id + ' make a response');
 }).listen(8000);
}
Copier après la connexion

Ce code est très simple. Le thread principal est le fichier js en cours d'exécution. Le thread principal crée des processus enfants en fonction du nombre de cœurs de votre. système local. Tous les processus partagent un port d'écoute 8000. Lorsqu'une requête est lancée, le thread principal attribuera aléatoirement la requête à un processus enfant. console.log('Worker #' + cluster.worker.id + ' make a response');Ce code peut imprimer quel processus gère la demande.

Analyse du problème

Nous avons mentionné plus tôt que lorsqu'une demande est lancée, le système décide à quel processus transmettre la demande pour traitement. Ce type d'équilibrage de charge qui repose entièrement sur le système présente un défaut important : sous Windows, Linux et Solaris, tant que la file d'attente d'acceptation d'un certain sous-processus est vide (généralement le dernier sous-processus créé), le système utiliser plusieurs connexions affectées au même sous-processus, cela entraînera une charge extrêmement inégale entre les processus. Surtout lors de l'utilisation de connexions longues, le nombre de nouvelles connexions entrantes par unité de temps n'est pas élevé et la file d'attente d'acceptation du processus enfant est souvent vide, ce qui entraînera l'allocation continue des connexions au même processus. Par conséquent, ce type d'équilibrage de charge dépend entièrement de l'inactivité de la file d'attente d'acceptation. L'équilibrage de charge ne peut être obtenu que lorsque des connexions courtes sont utilisées et que la concurrence est très élevée. Cependant, à ce stade, la charge du système sera très élevée. le système deviendra instable.

Résumé

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Explication graphique détaillée de la mémoire et du GC du moteur Node V8 Explication graphique détaillée de la mémoire et du GC du moteur Node V8 Mar 29, 2023 pm 06:02 PM

Cet article vous donnera une compréhension approfondie de la mémoire et du garbage collector (GC) du moteur NodeJS V8. J'espère qu'il vous sera utile !

Un article pour parler du contrôle de la mémoire dans Node Un article pour parler du contrôle de la mémoire dans Node Apr 26, 2023 pm 05:37 PM

Le service Node construit sur une base non bloquante et piloté par les événements présente l'avantage d'une faible consommation de mémoire et est très adapté à la gestion de requêtes réseau massives. Dans le contexte de demandes massives, les questions liées au « contrôle de la mémoire » doivent être prises en compte. 1. Le mécanisme de récupération de place du V8 et les limitations de mémoire Js sont contrôlés par la machine de récupération de place

Parlons de la façon de choisir la meilleure image Docker Node.js ? Parlons de la façon de choisir la meilleure image Docker Node.js ? Dec 13, 2022 pm 08:00 PM

Le choix d'une image Docker pour Node peut sembler trivial, mais la taille et les vulnérabilités potentielles de l'image peuvent avoir un impact significatif sur votre processus CI/CD et votre sécurité. Alors, comment choisir la meilleure image Docker Node.js ?

Parlons en profondeur du module File dans Node Parlons en profondeur du module File dans Node Apr 24, 2023 pm 05:49 PM

Le module de fichiers est une encapsulation des opérations de fichiers sous-jacentes, telles que l'ajout de lecture/écriture/ouverture/fermeture/suppression de fichiers, etc. La plus grande caractéristique du module de fichiers est que toutes les méthodes fournissent deux versions de **synchrone** et ** asynchrone**, with Les méthodes avec le suffixe sync sont toutes des méthodes de synchronisation, et celles qui n'en ont pas sont toutes des méthodes hétérogènes.

Node.js 19 est officiellement sorti, parlons de ses 6 fonctionnalités majeures ! Node.js 19 est officiellement sorti, parlons de ses 6 fonctionnalités majeures ! Nov 16, 2022 pm 08:34 PM

Node 19 est officiellement publié. Cet article vous donnera une explication détaillée des 6 fonctionnalités majeures de Node.js 19. J'espère qu'il vous sera utile !

Parlons du mécanisme GC (garbage collection) dans Node.js Parlons du mécanisme GC (garbage collection) dans Node.js Nov 29, 2022 pm 08:44 PM

Comment Node.js fait-il le GC (garbage collection) ? L’article suivant vous guidera à travers cela.

Parlons de la boucle d'événements dans Node Parlons de la boucle d'événements dans Node Apr 11, 2023 pm 07:08 PM

La boucle d'événements est un élément fondamental de Node.js et permet une programmation asynchrone en garantissant que le thread principal n'est pas bloqué. Comprendre la boucle d'événements est crucial pour créer des applications efficaces. L'article suivant vous donnera une compréhension approfondie de la boucle d'événements dans Node. J'espère qu'il vous sera utile !

Que dois-je faire si le nœud ne peut pas utiliser la commande npm ? Que dois-je faire si le nœud ne peut pas utiliser la commande npm ? Feb 08, 2023 am 10:09 AM

La raison pour laquelle le nœud ne peut pas utiliser la commande npm est que les variables d'environnement ne sont pas configurées correctement. La solution est la suivante : 1. Ouvrez "Propriétés système" ; 2. Recherchez "Variables d'environnement" -> "Variables système", puis modifiez l'environnement. variables ; 3. Recherchez l'emplacement du dossier nodejs ; 4. Cliquez sur "OK".

See all articles