Sur quoi est basé le mécanisme asynchrone du nœud ?
Le mécanisme asynchrone du nœud est basé sur des « événements ». Toutes les requêtes d'E/S, de communication réseau et de base de données sont exécutées de manière non bloquante et les résultats renvoyés sont traités par la boucle d'événements. Le nœud ne traitera qu'un seul événement à la fois et entrera immédiatement dans la boucle d'événements pour vérifier les événements suivants une fois terminé. De cette manière, le processeur et la mémoire peuvent se concentrer sur le traitement d'une seule chose en même temps, tout en essayant de permettre l'exécution en parallèle d'E/S et d'autres opérations fastidieuses.
L'environnement d'exploitation de ce tutoriel : système Windows 7, nodejs version 16, ordinateur DELL G3.
NodeJS est monothread. Le monothreading présente les avantages suivants :
Simple
Hautes performances, évitant les frais généraux liés aux changements fréquents de thread
Il consomme moins de ressources car il est unique. -threadé et sous forte charge Dans ce cas, l'utilisation de la mémoire est toujours très faible
Thread-safe, il n'y a aucun problème tel que le verrouillage, le déverrouillage et le blocage
Comment résoudre une concurrence élevée ?
node utilise des E/S asynchrones et pilotées par les événements (fonction de rappel) pour résoudre le problème de la concurrence élevée.
De manière générale, les solutions à haute concurrence fourniront un modèle multithread, fournissant un thread pour chaque logique métier et compensant le temps nécessaire aux appels d'E/S synchrones via la commutation de thread système. Comme Apache, il y a un thread par requête.
NodeJS utilise un modèle monothread et utilise des méthodes de requête asynchrones pour toutes les E/S afin d'éviter des changements de contexte fréquents. Il maintient une file d'attente d'événements lorsque NodeJS est exécuté, lorsque le programme est exécuté, il entre dans la boucle d'événements et attend le résultat ; la suivante. Lorsqu'un événement arrive, chaque demande d'E/S asynchrone sera poussée vers la file d'attente des événements pour attendre son exécution.
Le mécanisme asynchrone de NodeJS est basé sur des événements. Toutes les requêtes d'E/S, de communication réseau et de base de données sont exécutées de manière non bloquante et les résultats renvoyés sont traités par la boucle d'événements. Comme le montre l'image :
Le processus Node.js ne traitera qu'un seul événement à la fois. Une fois terminé, il entrera immédiatement dans la boucle d'événements pour vérifier les événements suivants. L'avantage est que le processeur et la mémoire peuvent se concentrer sur le traitement d'une seule chose en même temps, tout en essayant de permettre l'exécution en parallèle d'E/S et d'autres opérations fastidieuses. Pour les attaques de connexion à faible vitesse, Node.js ajoute uniquement des requêtes à la file d'attente des événements et attend la réponse du système d'exploitation. Il n'y a donc pas de surcharge multithread, ce qui peut considérablement améliorer la robustesse des applications Web et empêcher les attaques malveillantes.
Mécanisme de boucle d'événement
La soi-disant boucle d'événement signifie que NodeJS utilisera le mécanisme d'événement pour résoudre toutes les opérations asynchrones. Il existe un thread qui boucle constamment pour détecter la file d'attente d'événements.
Toute la logique dans NodeJS est la fonction de rappel des événements, donc NodeJS est toujours dans la boucle d'événements et l'entrée du programme est la fonction de rappel du premier événement de la boucle d'événements. La fonction de rappel d'événement peut émettre une requête d'E/S ou émettre directement l'événement et revenir à la boucle d'événements après l'exécution. La boucle d'événements vérifie la file d'attente des événements pour les événements non gérés jusqu'à la fin du programme. La boucle d'événements de NodeJS est invisible pour les développeurs et est implémentée par la bibliothèque libev. libev vérifie en permanence s'il existe des écouteurs d'événements actifs qui peuvent être détectés et ne quitte pas la boucle d'événements tant qu'aucun écouteur d'événements n'est détecté et que le programme se termine.
Pour plus de connaissances sur les nœuds, veuillez visiter : tutoriel nodejs !
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Comment supprimer un nœud avec nvm : 1. Téléchargez « nvm-setup.zip » et installez-le sur le lecteur C ; 2. Configurez les variables d'environnement et vérifiez le numéro de version via la commande « nvm -v » 3. Utilisez la commande « nvm » ; install" commande Installer le nœud ; 4. Supprimez le nœud installé via la commande "nvm uninstall".

Comment gérer le téléchargement de fichiers ? L'article suivant vous expliquera comment utiliser Express pour gérer les téléchargements de fichiers dans le projet de nœud. J'espère qu'il vous sera utile !

Cet article partagera avec vous l'outil de gestion de processus de Node "pm2" et expliquera pourquoi pm2 est nécessaire, comment installer et utiliser pm2, j'espère qu'il sera utile à tout le monde !

Explication détaillée et guide d'installation pour les nœuds de pignon Cet article introduira l'écosystème de pignon en détail - nœuds PI, un rôle clé dans l'écosystème de pignon et fournir des étapes complètes pour l'installation et la configuration. Après le lancement du réseau de test de la blockchain pèse, les nœuds PI sont devenus une partie importante de nombreux pionniers participant activement aux tests, se préparant à la prochaine version du réseau principal. Si vous ne connaissez pas encore Pinetwork, veuillez vous référer à ce qu'est Picoin? Quel est le prix de l'inscription? PI Utilisation, exploitation minière et sécurité. Qu'est-ce que Pinetwork? Le projet Pinetwork a commencé en 2019 et possède sa pièce exclusive de crypto-monnaie PI. Le projet vise à en créer un que tout le monde peut participer

Comment empaqueter le fichier exécutable nodejs avec pkg ? L'article suivant vous expliquera comment utiliser pkg pour empaqueter un projet Node dans un fichier exécutable. J'espère qu'il vous sera utile !

npm node gyp a échoué car les versions de « node-gyp.js » et « Node.js » ne correspondaient pas. La solution : 1. Videz le cache du nœud via « npm cache clean -f » 2. Via « npm install - ». g n" Installez le module n ; 3. Installez la version "node v12.21.0" via la commande "n v12.21.0".

Qu'est-ce qu'un système d'authentification unique ? Comment l'implémenter en utilisant nodejs ? L'article suivant vous présentera comment utiliser Node pour implémenter un système d'authentification unique. J'espère qu'il vous sera utile !

L'authentification est l'une des parties les plus importantes de toute application Web. Ce didacticiel traite des systèmes d'authentification basés sur des jetons et de leurs différences par rapport aux systèmes de connexion traditionnels. À la fin de ce didacticiel, vous verrez une démo entièrement fonctionnelle écrite en Angular et Node.js. Systèmes d'authentification traditionnels Avant de passer aux systèmes d'authentification basés sur des jetons, examinons les systèmes d'authentification traditionnels. L'utilisateur fournit son nom d'utilisateur et son mot de passe dans le formulaire de connexion et clique sur Connexion. Après avoir effectué la demande, authentifiez l'utilisateur sur le backend en interrogeant la base de données. Si la demande est valide, une session est créée à l'aide des informations utilisateur obtenues à partir de la base de données et les informations de session sont renvoyées dans l'en-tête de réponse afin que l'ID de session soit stocké dans le navigateur. Donne accès aux applications soumises à
