Travailler avec des variables d'environnement en Node.js
Travailler avec des variables d'environnement est un excellent moyen de configurer différents aspects de votre application Node.js. De nombreux hôtes cloud (Heroku, Azure, AWS, now.sh, etc.) et modules Node.js utilisent des variables d'environnement. Les hôtes, par exemple, définiront une variable PORT
spécifiant le port sur lequel le serveur devrait écouter pour fonctionner correctement. Les modules pourront avoir des comportements différents (comme la journalisation) en fonction de la valeur de la variable NODE_ENV
.
Voici quelques-uns de mes trucs et outils quand je travaille avec des variables d'environnement dans Node.js.
Les bases
L'accès aux variables d'environnement dans Node.js est pris en charge par défaut. Lorsque votre processus Node.js démarre, il fournit automatiquement un accès à toutes les variables d'environnement existantes en créant un objet env
en tant que propriété de l'objet global process
. Si vous voulez jeter un coup d'œil à l'objet, exécutez l'environnement Node.js REPL avec node
dans votre ligne de commande, et tapez :
Ce code devrait produire l'ensemble des variables d'environnement dont ce processus Node.js a connaissance. Pour accéder à une variable spécifique, faites comme pour n'importe quelle propriété d'un objet :
Vous devriez voir que la valeur de PORT
est undefined
sur votre ordinateur. Cependant, les hôtes cloud comme Heroku ou Azure utilisent la variable PORT
pour vous indiquer sur quel port votre serveur devrait écouter pour que le routage fonctionne correctement. Par conséquent, la prochaine fois que vous configurerez un serveur web, vous devrez déterminer le port à écouter en vérifiant d'abord PORT
et en lui donnant dans le cas contraire une valeur par défaut :
La ligne mise en surbrillance prendra la valeur du PORT
si elle est disponible, ou la valeur par défaut de 3000
en tant que port sécurisé sur lequel écouter. Essayez d'exécuter le code en l'enregistrant dans un fichier tel que server.js
puis exécutez :
La sortie devrait être un message indiquant Server is listening on port 3000
. Arrêtez le serveur à l'aide des touches Ctrl+C
et redémarrez-le à l'aide de la commande suivante :
Le message devrait maintenant dire Server is listening on port 9999
car la variable PORT
a été temporairement définie pour cette exécution par le PORT=9999
devant node
.
Puisque process.env
est simplement un objet normal, nous pouvons définir/remplacer les valeurs très facilement :
Le code ci-dessus définira ou remplacera la valeur MY_VARIABLE
. Cependant, gardez à l'esprit que cette valeur n'est définie que pendant l'exécution de ce processus Node.js, et n'est disponible que dans les processus enfants générés par ce processus. En règle générale, évitez autant que possible de remplacer les variables d'environnement, et initialisez plutôt une variable de configuration comme indiqué dans l'exemple PORT
.
Charger explicitement des variables depuis des fichiers .env
Si vous développez sur différents projets Node.js depuis un même ordinateur, il se peut que vous vous retrouviez avec des chevauchements des noms de variables d'environnement. Par exemple, différentes applications de messagerie pourront avoir besoin de différents SID de service de messagerie Twilio, mais les deux s'appelleront TWILIO_MESSAGE_SERVICE_SID
. Un excellent moyen d'obtenir une configuration spécifique au projet est d'utiliser des fichiers .env
. Ceux-ci permettent de spécifier toute une variété de variables d'environnement différentes et leurs valeurs.
En principe, vous ne voulez pas suivre ces fichiers dans le contrôle de source, donc lorsque vous en créez un, vous devez ajouter .env
à votre .gitignore
. Vous verrez dans de nombreuses applications de démonstration Twilio des fichiers .env.example
que vous pourrez ensuite copier vers .env
et qui vous permettront de définir les valeurs vous-même. Une pratique courante consiste à avoir un fichier .env.example
ou similaire si vous voulez partager un fichier modèle avec d'autres personnes du projet.
Comment charger les valeurs à partir de ce fichier ? La façon la plus simple est d'utiliser un module npm appelé dotenv. Il vous suffit d'installer le module via npm :
Ajoutez ensuite la ligne suivante tout en haut de votre fichier d'entrée :
Ce code chargera automatiquement le fichier .env
à la racine de votre projet et initialisera les valeurs. Toutes les variables déjà définies seront ignorées. Cela dit, vous ne devriez pas utiliser de fichiers .env
dans votre environnement de production, mais définir plutôt les valeurs directement sur l'hôte correspondant. Par conséquent, il pourrait être judicieux d'encapsuler votre instruction « load » dans une instruction « if » :
Avec ce code, nous ne chargerons le fichier .env
que si le serveur n'est pas démarré en mode production.
Voyons cela en action. Installez dotenv
dans un répertoire comme indiqué ci-dessus. Créez un fichier dotenv-example.js
dans le même répertoire et insérez-y les lignes suivantes :
Ensuite, créez un fichier nommé .env
dans le même répertoire, avec le contenu suivant :
Exécutez le script :
La sortie devrait ressembler à :
Comme vous pouvez le voir, la valeur a été chargée et définie à l'aide de dotenv
. Si vous réexécutez la même commande avec NODE_ENV
définie sur production
, vous verrez qu'elle restera undefined
.
La sortie devrait maintenant être :
Si vous ne voulez pas modifier votre code en lui-même, vous pouvez également utiliser l'argument -r
de Node pour charger dotenv
lors de l'exécution du script. Modifiez votre fichier dotenv-example.js
:
Ensuite, exécutez d'abord le fichier normalement :
Le script devrait indiquer que la valeur actuelle pour FOO
est undefined
. Exécutez-le maintenant avec l'indicateur approprié pour appeler dotenv
:
Le résultat est que FOO
est maintenant définie sur bar
depuis que le fichier .env
a été chargé.
Si vous souhaitez en savoir plus sur dotenv, consultez sa documentation.
Charger autrement des fichiers .env
dotenv
est certes génial, mais il y a une chose en particulier qui m'a personnellement gêné au cours du processus de développement : il ne remplace pas les variables env existantes et vous ne pouvez pas l'y forcer.
J'étais si frustré que j'ai décidé d'écrire mon propre module basé sur dotenv
afin de résoudre ce problème et de rendre le chargement de variables d'environnement plus pratique. Le résultat est node-env-run
ou nodenv. Il s'agit d'un outil de ligne de commande qui charge un fichier .env
, initialise les valeurs à l'aide de dotenv
, puis exécute votre script.
Vous pouvez l'installer globalement, mais je vous recommande de l'utiliser uniquement à des fins de développement et au niveau local du projet. Installez-le en exécutant :
Ensuite, créez un fichier nodenv-example.js
et insérez-y ce code :
Comme vous pouvez le voir, nous n'avons pas besoin d'appeler quoi que ce soit ici. Il s'agit simplement de la logique applicative. Essayez d'abord de l'exécuter à l'aide de node
:
Ce code exécuté devrait générer The value for FOO is: undefined
. Essayez maintenant d'utiliser node-env-run
en exécutant :
Le résultat devrait être The value for FOO is: bar
dans la mesure où il a chargé le fichier .env
.
Node-env-run
peut remplacer les valeurs existantes. Pour le voir en action, exécutez d'abord la commande suivante :
La sortie de ligne de commande devrait indiquer The value for Foo is: foo
. Si nous activons maintenant le mode force, nous pouvons remplacer les valeurs existantes :
Par conséquent, nous devrions revenir au The value for FOO is: bar
initial.
Si vous souhaitez utiliser cet outil régulièrement, je vous recommande de l'encapsuler dans un script npm. En l'ajoutant dans package.json
comme suit :
Vous pouvez ainsi exécuter en toute simplicité :
Si vous souhaitez en savoir plus sur node-env-run, consultez sa documentation.
Variables d'environnement && scripts npm
Dans certains scénarios, il est utile de vérifier la valeur d'une variable d'environnement avant d'entrer dans l'application Node.js en scripts npm. Par exemple, si vous souhaitez utiliser node-env-run
lorsque vous êtes dans un environnement de développement, mais node
lorsque vous êtes en mode production
. Un outil permet de le faire très facilement : if-env. Installez-le en exécutant :
Assurez-vous de ne pas l'installer en tant que « dépendance de développement » car nous en aurons aussi besoin en production.
Maintenant, il vous suffit de modifier vos scripts npm dans votre package.json
:
Ce script va dès lors exécuter npm run start:prod
, puis node .
si NODE_ENV
a la valeur production
, et dans le cas contraire exécuteranpm run start:dev
, puis nodenv -f .
. Vous pouvez également utiliser cette technique avec n'importe quelle autre variable d'environnement.
Essayez par exemple en exécutant :
Si vous souhaitez en savoir plus sur if-env, consultez sa documentation.
Débogage
On connaît tous ce moment où les choses ne fonctionnent pas comme on le souhaiterait et où un module ne fait pas ce qu'il est censé faire. Le moment est alors venu de déboguer. Une stratégie qui m'a beaucoup aidé a été d'utiliser la variable d'environnement DEBUG
afin de recevoir des journaux plus détaillés pour un groupe de modules. Par exemple, si vous prenez un serveur express
de base comme celui-ci :
Et que vous le lancez avec la variable DEBUG
définie sur *
:
Vous recevrez une série de logs détaillés qui ressemblent à ceci :
La « magie » s'opère grâce à un module léger appelé debug extrêmement facile d'utilisation. Lorsque vous voulez l'utiliser, il vous suffit de l'initialiser avec un « espace de nom ». Vous pouvez ensuite vous connecter à cet espace de nom. Si quelqu'un veut voir la sortie, il lui suffit d'activer l'espace de nom dans la variable DEBUG
. Dans notre cas, express
utilise un groupe de sous-espaces de noms. Si vous voulez tout ce qui provient du routeur express
, il vous suffit de paramétrer DEBUG
sur le caractère générique approprié :
Si vous souhaitez utiliser debug
dans votre propre module, il vous suffit d'abord de l'installer :
Vous pouvez ensuite le consommer de la manière suivante :
Si vous souhaitez en savoir plus sur le débogage assurez-vous de consulter la documentation.
Utilisez maintenant toutes les variables d'environnement !
Bien loin d'être les seules choses que vous pouvez faire avec les variables d'environnement ni les seuls outils disponibles, il s'agit ici simplement de ceux que j'utilise le plus souvent. Si vous utilisez régulièrement d'autres outils remarquables, je serais ravi d'en savoir plus !
Maintenant que vous en savez un peu plus sur les variables d'environnement dans Node.js, essayez les kits de démarrage rapide Node.js de Twilio !
Articles associés
Ressources connexes
Twilio Docs
Des API aux SDK en passant par les exemples d'applications
Documentation de référence sur l'API, SDK, bibliothèques d'assistance, démarrages rapides et didacticiels pour votre langage et votre plateforme.
Centre de ressources
Les derniers ebooks, rapports de l'industrie et webinaires
Apprenez des experts en engagement client pour améliorer votre propre communication.
Ahoy
Le hub de la communauté des développeurs de Twilio
Meilleures pratiques, exemples de code et inspiration pour créer des expériences de communication et d'engagement numérique.