recherche
Maisoninterface Webjs tutoriel5 ajustements de performances faciles pour Node.js Express

5 Easy Performance Tweaks for Node.js Express

Points clés

  • Le passage au mode de production peut considérablement améliorer les performances des applications express, car le mode de production élimine les tâches de trace de journalisation et d'exception en mode de développement.
  • Activer la compression GZIP dans Express 4.x peut réduire la charge HTTP et améliorer les performances. Cela peut être fait en installant le module de compression et en l'utilisant comme première fonction middleware.
  • La suppression du middleware inutile, en considérant l'utilisation d'un moteur de modèle plus simple, et la mise en cache efficace des variables communes peut encore optimiser les performances des applications express. Des outils de construction tels que Gulp peuvent être utilisés pour comprimer et fusionner les modèles HTML, les fichiers CSS et JavaScript, et les variables de session doivent être limitées pour éviter les problèmes de performances liés à la mémoire.

Node.js a complètement changé le développement Web, et le cadre express a apporté une contribution indélébile. Express n'est peut-être pas l'option de serveur la plus rapide ou la plus avancée, mais c'est presque certainement la plus utilisée, avec plus de 3 millions de téléchargements par mois. Si vous ne faites rien, Node.js et Express fonctionneront également très rapidement. Cependant, il existe des moyens faciles de faire fonctionner Express 4.x plus rapidement ...

  1. Passer en mode de production

Express peut être exécuté en plusieurs modes. Par défaut, il suppose que le mode de développement, qui fournit des traces de pile d'exception et d'autres tâches de journalisation. Il existe également un mode de débogage qui enregistre les messages à la console, par exemple:

<code>DEBUG=express:* node ./app.js</code>

Sur votre serveur en direct, vous pouvez améliorer considérablement les performances en passant en mode de production. Cela peut être fait en définissant la variable d'environnement Node_env à la production. Il peut être défini dans la session actuelle de Windows avant de démarrer l'application Express:

<code>set NODE_ENV=production</code>

ou mac / linux:

<code>export NODE_ENV=production</code>

Les utilisateurs de Linux peuvent également définir Node_env dans une ligne au démarrage:

<code>NODE_ENV=production node ./app.js</code>

Idéalement, vous devez configurer votre environnement en ajoutant <code>export NODE_ENV=production</code> à votre ~/.bash_profile ou au script de démarrage correspondant.

  1. Activer gzip

Express 4.x fournit le moins de fonctionnalités disponibles qui peuvent être améliorées avec le middleware. Une caractéristique manquante moins évidente est la compression GZIP, ce qui réduit la charge HTTP afin que le navigateur puisse l'étendre lorsqu'il reçoit. Pour ajouter GZIP, utilisez NPM pour installer le module de compression:

<code>npm install compression --save</code>

(Selon votre configuration, vous devrez peut-être utiliser Sudo sur Mac / Linux - il existe de nombreuses façons de résoudre ce problème.) Dans votre fichier de démarrage d'application principal, incluez le module de compression:

<code>var compression = require('compression');</code>

puis installez-le comme première fonction middleware (avant les autres méthodes d'express .User):

<code>DEBUG=express:* node ./app.js</code>
  1. supprimer le middleware inutile

Si vous avez généré une application pré-construite à l'aide d'un générateur express ou de procédures similaires, supprimez les modules de middleware que vous n'avez pas utilisés. Par exemple, si vous n'utilisez pas de cookies, vous pouvez supprimer le module de cookie-parser ou utiliser req.cookies et res.cookies pour implémenter une alternative plus simple. En mode de production, certains processus peuvent être supprimés, tels que la sortie de débogage, par exemple:

<code>set NODE_ENV=production</code>

En d'autres termes, il est préférable de continuer à servir. Le navigateur demande fréquemment le fichier favicon.ico et le module peut améliorer la mise en cache.

  1. Envisagez d'utiliser un moteur de modèle plus simple

Jade est le moteur de modèle par défaut pour de nombreuses installations express, et c'est un bon choix. Cependant, si vous êtes heureux d'écrire votre propre HTML et que vous avez uniquement besoin d'interpolation et d'évaluation de base, envisagez d'utiliser une alternative légère, telle que DOT, qui peut être ajoutée comme middleware express à l'aide du module express-dot-moteur. Alternativement, vous pouvez contourner le moteur de modèle pour une réponse plus simple, telle que:

<code>export NODE_ENV=production</code>

Assurez-vous toujours que la mise en cache de vue est activée, quel que soit le moteur de modèle que vous utilisez:

<code>NODE_ENV=production node ./app.js</code>
  1. N'oubliez pas le cache!

Contrairement à la plupart des applications basées sur le serveur, l'application Node.js s'exécute en permanence. Ainsi, vous pouvez définir des variables communes comme les objets de connexion de la base de données une fois et les réutiliser lors de chaque demande pour chaque utilisateur. Ce concept peut être étendu au besoin. D'une manière générale, plus vous pouvez cacher les éléments les plus courants, meilleur est les performances. Par exemple, supposons que votre application CMS basée sur Express affiche des liens vers vos cinq derniers articles sur la page d'accueil. La liste peut être générée et stockée dans une variable et n'est mise à jour que lorsque de nouveaux articles sont publiés.

Conseils supplémentaires supplémentaires

En voulez-vous plus? …

  • Envisagez d'utiliser Nginx pour servir le contenu statique et réduire la charge sur Node.js et Express.
  • Utilisez des outils de construction tels que Gulp pour compresser et fusionner vos modèles HTML, CSS et vos fichiers JavaScript.
  • Limitez l'utilisation des variables de session. Les données de session utilisateur sont généralement stockées en mémoire, ce qui peut entraîner des problèmes de performances à mesure que l'utilisation augmente. Envisagez d'utiliser uniquement des ID, puis d'obtenir des informations utilisateur à partir de la base de données pendant la demande.
  • Augmentez le nombre maximum de prises HTTP de cinq à des nombres plus élevés, par exemple:
<code>npm install compression --save</code>
  • Si possible, appelez des séquences d'opérations de blocage au lieu de séquentiellement.
  • Évitez d'utiliser des appels de blocage synchrones dans tout sauf l'initialisation de l'application.
  • Notez toujours que le code s'exécute pour un utilisateur de blocs de code de code pour l'autre utilisateur.

Avez-vous d'autres conseils de performances pour Node.js ou Express? J'adorerais les entendre dans les commentaires.

(Le chapitre sur les FAQ sur le réglage des performances de Node.js doit être ajouté ici, le même contenu que celui prévu dans le texte d'entrée)

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
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
Remplacer les caractères de chaîne en javascriptRemplacer les caractères de chaîne en javascriptMar 11, 2025 am 12:07 AM

Explication détaillée de la méthode de remplacement de la chaîne JavaScript et de la FAQ Cet article explorera deux façons de remplacer les caractères de chaîne dans JavaScript: le code JavaScript interne et le HTML interne pour les pages Web. Remplacer la chaîne dans le code JavaScript Le moyen le plus direct consiste à utiliser la méthode Remplace (): str = str.replace ("trouver", "remplacer"); Cette méthode remplace uniquement la première correspondance. Pour remplacer toutes les correspondances, utilisez une expression régulière et ajoutez le drapeau global G: str = str.replace (/ fi

Comment créer et publier mes propres bibliothèques JavaScript?Comment créer et publier mes propres bibliothèques JavaScript?Mar 18, 2025 pm 03:12 PM

L'article discute de la création, de la publication et du maintien des bibliothèques JavaScript, en se concentrant sur la planification, le développement, les tests, la documentation et les stratégies de promotion.

Comment optimiser le code JavaScript pour les performances dans le navigateur?Comment optimiser le code JavaScript pour les performances dans le navigateur?Mar 18, 2025 pm 03:14 PM

L'article traite des stratégies pour optimiser les performances JavaScript dans les navigateurs, en nous concentrant sur la réduction du temps d'exécution et la minimisation de l'impact sur la vitesse de chargement de la page.

Comment déboguer efficacement le code JavaScript à l'aide d'outils de développeur de navigateur?Comment déboguer efficacement le code JavaScript à l'aide d'outils de développeur de navigateur?Mar 18, 2025 pm 03:16 PM

L'article traite du débogage efficace de JavaScript à l'aide d'outils de développeur de navigateur, de se concentrer sur la définition des points d'arrêt, de l'utilisation de la console et d'analyser les performances.

Effets de la matrice jQueryEffets de la matrice jQueryMar 10, 2025 am 12:52 AM

Apportez des effets de film de matrice à votre page! Ceci est un plugin jQuery cool basé sur le célèbre film "The Matrix". Le plugin simule les effets de caractère vert classique dans le film, et sélectionnez simplement une image et le plugin le convertira en une image de style matrice remplie de caractères numériques. Venez et essayez, c'est très intéressant! Comment ça marche Le plugin charge l'image sur la toile et lit le pixel et les valeurs de couleur: data = ctx.getImagedata (x, y, settings.grainsize, settings.grainsize) .data Le plugin lit intelligemment la zone rectangulaire de l'image et utilise jQuery pour calculer la couleur moyenne de chaque zone. Ensuite, utilisez

Comment construire un simple curseur jQueryComment construire un simple curseur jQueryMar 11, 2025 am 12:19 AM

Cet article vous guidera pour créer un carrousel d'image simple à l'aide de la bibliothèque JQuery. Nous utiliserons la bibliothèque BXSLider, qui est construite sur jQuery et offre de nombreuses options de configuration pour configurer le carrousel. De nos jours, Picture Carrousel est devenue une fonctionnalité incontournable sur le site Web - une image vaut mieux que mille mots! Après avoir décidé d'utiliser le carrousel d'image, la question suivante est de savoir comment la créer. Tout d'abord, vous devez collecter des images de haute qualité et haute résolution. Ensuite, vous devez créer un carrousel d'image en utilisant HTML et un code JavaScript. Il existe de nombreuses bibliothèques sur le Web qui peuvent vous aider à créer des carrousels de différentes manières. Nous utiliserons la bibliothèque BXSLider open source. La bibliothèque Bxslider prend en charge la conception réactive, de sorte que le carrousel construit avec cette bibliothèque peut être adapté à n'importe quel

Amélioration du balisage structurel avec JavaScriptAmélioration du balisage structurel avec JavaScriptMar 10, 2025 am 12:18 AM

Points clés Le marquage structuré amélioré avec JavaScript peut considérablement améliorer l'accessibilité et la maintenabilité du contenu de la page Web tout en réduisant la taille du fichier. JavaScript peut être utilisé efficacement pour ajouter dynamiquement des fonctionnalités aux éléments HTML, tels que l'utilisation de l'attribut CITE pour insérer automatiquement les liens de référence en références de bloc. L'intégration de JavaScript avec des balises structurées vous permet de créer des interfaces utilisateur dynamiques, telles que des panneaux d'onglet qui ne nécessitent pas de rafraîchissement de page. Il est crucial de s'assurer que les améliorations JavaScript ne gênent pas la fonctionnalité de base des pages Web; même si JavaScript est désactivé, la page doit rester fonctionnelle. La technologie avancée JavaScript peut être utilisée (

Comment télécharger et télécharger des fichiers CSV avec AngularComment télécharger et télécharger des fichiers CSV avec AngularMar 10, 2025 am 01:01 AM

Les ensembles de données sont extrêmement essentiels pour créer des modèles d'API et divers processus métier. C'est pourquoi l'importation et l'exportation de CSV sont une fonctionnalité souvent nécessaire. Dans ce tutoriel, vous apprendrez à télécharger et à importer un fichier CSV dans un

See all articles

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

SublimeText3 version anglaise

SublimeText3 version anglaise

Recommandé : version Win, prend en charge les invites de code !

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Version Mac de WebStorm

Version Mac de WebStorm

Outils de développement JavaScript utiles

SublimeText3 version Mac

SublimeText3 version Mac

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

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux