Tutorial

Comment redémarrer vos applications Node.js automatiquement avec nodemon

Published on November 23, 2020
authorauthor

Alligator.io and Bradley Kouchi

Français
Comment redémarrer vos applications Node.js automatiquement avec nodemon

Introduction

Sous Node.js, vous devez redémarrer le processus pour que les changements prennent effet, une étape supplémentaire qui s’ajoute à votre flux de travail pour que les modifications soient implémentées. En utilisant nodemon, vous pouvez éliminer cette étape supplémentaire car il se chargera de redémarrer le processus automatiquement.

nodemon est un utilitaire d’interface de ligne de commande (CLI) développé par @rem. Il enveloppe votre application Node, surveille le système de fichiers et redémarre automatiquement le processus.

Cet article vous permettra d’en apprendre davantage sur l’installation, le réglage et la configuration de nodemon.

Conditions préalables

Pour suivre les étapes de cet article, vous aurez besoin de ce qui suit :

Étape 1 — Installation de nodemon

En premier lieu, vous devez installer nodemon sur votre machine. Installez l’utilitaire soit globalement ou localement sur votre projet en utilisant npm ou Yarn  :

Installation globale

Vous pouvez installer nodemon de manière globale avec npm :

  1. npm install nodemon -g

Ou avec Yarn :

  1. yarn global add nodemon

Installation locale

Vous pouvez également utiliser npm pour installer nodemon localement. Pour procéder à une installation locale, nous pouvons installer nodemon sous la forme d’une dev dependency avec --save-dev (ou --dev) :

  1. npm install nodemon --save-dev

Ou avec Yarn :

  1. yarn add nodemon --dev

Il y a cependant une chose à retenir concernant une installation locale. Il vous sera impossible d’utiliser la commande nodemon directement à partir de la ligne de commande suivante :

  1. Output
    command not found: nodemon

Vous pouvez cependant l’utiliser dans le cadre de certains scripts npm ou avec npx.

Vous venez de terminer le processus d’installation de nodemon. Maintenant, nous allons utiliser nodemon avec nos projets.

Étape 2 — Configuration d’un exemple du projet Express avec nodemon

Nous pouvons utiliser nodemon pour lancer un script Node. Si, par exemple, la configuration du serveur Express se trouve dans un fichier server.js, nous pouvons la lancer et surveiller les modifications de la manière suivante :

  1. nodemon server.js

Vous pouvez transmettre les arguments de la même manière que pour exécuter le script avec Node :

  1. nodemon server.js 3006

Chaque fois que vous modifiez un fichier avec l’une des extensions surveillées par défaut (.js, .mjs, .json, .coffee ou .litcoffee) dans le répertoire ou le sous-répertoire actuel, le processus redémarrera.

Supposons que nous écrivions un exemple de fichier server.js qui déclenche le message suivant : Écoute de l'application Dolphin sur le port ${port} !.

Nous pouvons exécuter l’exemple avec nodemon :

  1. nodemon server.js

Nous obtiendrons le résultat suivant sur le terminal:

Output
[nodemon] 1.17.3 [nodemon] to restart at any time, enter `rs` [nodemon] watching: *.* [nodemon] starting `node server.js` Dolphin app listening on port 3000!

Alors que l’exécution de nodemon est toujours cours, modifions le fichier server.js de manière à qu’il fasse apparaître le message suivant :Écoute de l'application Shark sur le port ${port} !

Nous obtiendrons le résultat supplémentaire suivant sur le terminal :

Output
[nodemon] restarting due to changes... [nodemon] starting `node server.js` Shark app listening on port 3000!

Le résultat qui apparaît sur le terminal de notre application Node.js s’affiche comme prévu. À tout moment, vous pouvez redémarrer le processus en saisissant rs et en appuyant sur ENTRÉE.

Sinon, nodemon recherchera également le fichier main spécifié dans le fichier package.json de votre projet.

package.json
{
  // ...
  "main": "server.js",
  // ...
}

Ou, un script start :

package.json
{
  // ...
  "scripts": {
    "start": "node server.js"
  },
  // ...
}

Une fois que vous avez apporté vos modifications à package.json, vous pouvez alors appeler nodemon pour lancer l’application exemple en mode de surveillance sans avoir à passer par server.js.

Étape 3 — Utilisation des options

Vous pouvez modifier les paramètres de configuration disponibles sur nodemon.

Passons en revue quelques-unes des principales options :

  • --exec: utilisez le commutateur --exec pour spécifier le binaire avec lequel exécuter le fichier. Par exemple, combiné au binaire ts-node, --exec peut s’avérer utile pour surveiller les modifications et exécuter les fichiers TypeScript.
  • --ext : spécifiez les différentes extensions de fichier à surveiller. Pour cette commutation, vous devez fournir une liste séparée par une virgule des extensions de fichiers (par exemple, --ext js,ts).
  • --delay : lorsqu’un fichier est modifié, nodemon attend par défaut 1 seconde pour redémarrer le processus. Cependant, vous pouvez utiliser le commutateur --delay pour modifier ce délai. Par exemple, avec nodemon --delay 3.2 votre délai sera de 3,2 secondes.
  • --watch : utilisez le commutateur --watch pour une surveillance sur plusieurs répertoires ou fichiers. Activez un commutateur --watch pour chaque répertoire que vous souhaitez surveiller. Par défaut, le répertoire actuel et ses sous-répertoires sont surveillés. Donc, vous pouvez utiliser --watch pour limiter la surveillance à des sous-répertoires ou des fichiers spécifiques.
  • --ignore : utilisez le commutateur --ignore pour ignorer certains fichiers, modèles de fichiers ou répertoires.
  • --verbose : un résultat plus complet avec des informations sur le ou les fichiers modifiés pour déclencher un redémarrage.

Vous pouvez consulter toutes les options disponibles avec la commande suivante :

  1. nodemon --help

À l’aide de ces options, créons la commande qui satisfait au scénario suivant :

  • surveiller le répertoire server
  • spécifier les fichiers avec l’extension .ts
  • ignorer les fichiers avec le suffixe .test.ts.
  • exécuter le fichier (server/server.ts) avec ts-node.
  • attendre trois secondes pour procéder au redémarrage après modification d’un fichier
  1. nodemon --watch server --ext ts --exec ts-node --ignore '*.test.ts' --delay 3 server/server.ts

Cette commande combine les options --watch, --ext, --exec , --ignore, et --delay pour satisfaire aux conditions de notre scénario.

Étape 4 — Utilisation des configurations

Dans l’exemple précédent, l’ajout des commutateurs de configuration lors de l’exécution de nodemon est un exercice qui peut s’avérer être très fastidieux. Il existe une meilleure solution pour les projets qui nécessitent des configurations spécifiques. Elle consiste à spécifier ces configurations dans un fichier nodemon.json.

Par exemple, voici les mêmes configurations que celles de notre exemple précédent de ligne de commande, mais placées dans un fichier nodemon.json :

nodemon.json
{
  "watch": ["server"],
  "ext": "ts",
  "ignore": ["*.test.ts"],
  "delay": "3",
  "execMap": {
    "ts": "ts-node"
  }
}

Notez que nous utilisons execMap au lieu du commutateur --exec. execMap vous permet de spécifier les binaires à utiliser pour obtenir certaines extensions de fichier.

Ou alors, si vous ne souhaitez pas ajouter un fichier de configuration nodemon.json à votre projet, vous pouvez ajouter ces configurations dans un fichier package.json sous une clé nodemonConfig.

package.json
{
  "name": "test-nodemon",
  "version": "1.0.0",
  "description": "",
  "nodemonConfig": {
    "watch": [
      "server"
    ],
    "ext": "ts",
    "ignore": [
      "*.test.ts"
    ],
    "delay": "3",
    "execMap": {
      "ts": "ts-node"
    }
  },
  // ...

Une fois que vous avez apporté ces modifications à nodemon.json ou package.json, vous pouvez alors lancer nodemon avec le script que vous souhaitez :

  1. nodemon server/server.ts

nodemon récupérera les configurations et les utilisera. De cette façon, vos configurations pourront être enregistrées, partagées et répétées tout en évitant les erreurs de copier-coller ou de frappe dans la ligne de commande.

Conclusion

Cet article vous a permis d’apprendre à utiliser nodemon avec vos applications Node.js. Cet outil aide à automatiser le processus d’arrêt et de démarrage d’un serveur Node afin de pouvoir consulter les changements.

Pour de plus amples informations sur les fonctionnalités et les erreurs de dépannage, consultez la documentation officielle.

Si vous souhaitez en savoir plus sur Node.js, veuillez consulter notre page thématique Node.js dans laquelle vous trouverez des exercices et des projets de programmation.

Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.

Learn more about our products

About the authors
Default avatar
Alligator.io

author



Still looking for an answer?

Ask a questionSearch for more help

Was this helpful?
 
Leave a comment


This textbox defaults to using Markdown to format your answer.

You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!

Try DigitalOcean for free

Click below to sign up and get $200 of credit to try our products over 60 days!

Sign up

Join the Tech Talk
Success! Thank you! Please check your email for further details.

Please complete your information!

Become a contributor for community

Get paid to write technical tutorials and select a tech-focused charity to receive a matching donation.

DigitalOcean Documentation

Full documentation for every DigitalOcean product.

Resources for startups and SMBs

The Wave has everything you need to know about building a business, from raising funding to marketing your product.

Get our newsletter

Stay up to date by signing up for DigitalOcean’s Infrastructure as a Newsletter.

New accounts only. By submitting your email you agree to our Privacy Policy

The developer cloud

Scale up as you grow — whether you're running one virtual machine or ten thousand.

Get started for free

Sign up and get $200 in credit for your first 60 days with DigitalOcean.*

*This promotional offer applies to new accounts only.