Les applications Node.js sont populaires pour leur capacité à évoluer. L'exécution de plusieurs processus simultanés sur plusieurs serveurs entraîne une latence plus faible et une plus grande disponibilité. Lors de la gestion de plusieurs serveurs, il est plus facile de redémarrer automatiquement les applications Node.js en cas de panne. Ce didacticiel vous montrera comment configurer rapidement la persistance d'application à partir d'une instance vide d'Ubuntu 16.04.
Conditions préalables
- Créez une instance Vultr de n'importe quelle taille avec Ubuntu 16.04 LTS x64.
- Si vous n'êtes pas l'utilisateur root, exécutez
sudo -s
et saisissez votre mot de passe. Un accès root est requis pour modifier le fichier de démarrage afin que le gestionnaire de processus démarre au démarrage.
- Assurez-vous que Node.js est installé sur l'instance et que la version de Node.js est 8.9.3 LTS ou version ultérieure, ce qui est requis pour que le gestionnaire de persistance fonctionne correctement. Utilisez
node -v
pour vérifier la version installée. Si Node.js n'est pas sur la bonne version, les commandes suivantes l'installeront.
Installez Node.js.
$ sudo apt-get update
$ curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash -
$ sudo apt-get install -y nodejs
Créer une partition de swap
Cette étape est facultative, mais recommandée pour l'installation. Les partitions de swap sont des parties du disque dur qui sont dédiées à aider à compléter la RAM. Sur les petites instances Vultr, telles que l'instance de 512 Mo de RAM, la création d'une partition de swap serait bénéfique pour les performances. Pour une version automatisée du didacticiel d'échange, utilisez les commandes ci-dessous.
$ git clone https://github.com/teamtofu/server-tools.git tools
$ bash ./tools/swap.sh
De manière générale, l'utilisation de swap ne serait pas nécessaire pour les instances avec 4 Go de RAM ou plus lors de la configuration d'applications persistantes, bien qu'elle puisse améliorer les performances des applications. La RAM est plus réactive que le swap, donc les instances avec plus de RAM auront tendance à donner de meilleurs résultats indépendamment du swap.
Installer le fil
Yarn est un gestionnaire de packages facile à utiliser de Facebook pour les packages Node.js. Il est plus rapide que NPM et également déterministe, ce qui est particulièrement utile lors du déploiement de plusieurs serveurs.
$ curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | sudo apt-key add -
$ echo "deb https://dl.yarnpkg.com/debian/ stable main" | sudo tee /etc/apt/sources.list.d/yarn.list
$ sudo apt-get update && sudo apt-get install yarn
Cependant, NPM peut être utilisé à la place de Yarn, et il a des commandes comparables à toutes celles de ce tutoriel.
Installez votre application Node.js
Si votre application est hébergée dans un référentiel git, clonez-la et utilisez yarn install
. Votre application doit avoir un fichier d'entrée de serveur, généralement server.js
ou index.js
, qui sera utilisé dans les étapes suivantes.
Installer Process Manager 2
Process Manager 2 est le package qui redémarrera automatiquement l'application. Process Manager 2 est très populaire et est utilisé par Microsoft, PayPal et Intuit, il est donc sécurisé et fiable.
$ yarn global add pm2
Ajoutez votre application en tant que processus
L'application sera démonifiée (exécutée en arrière-plan) et redémarrée automatiquement avec la commande de démarrage.
$ pm2 start [path to your entry.js] -i max
Si vous souhaitez lancer automatiquement le nombre maximal de processus, passez l' -i max
argument. Si la seule utilisation de cette instance Vultr est de servir l'application, cela est recommandé. Pour les instances Vultr avec plus d'un processeur, plusieurs processus seront lancés et Process Manager 2 agira en tant qu'équilibreur de charge pour tous ces processus individuels.
Démarrez automatiquement votre application au démarrage
Après avoir démarré l'application, enregistrez la configuration de l'application. Ensuite, exécutez la commande de démarrage pour exécuter automatiquement Process Manager 2 en arrière-plan au démarrage d'Ubuntu. Pour Ubuntu 16.04, Process Manager 2 se liera à systemd
.
$ pm2 save
$ pm2 startup
Maintenant, si votre application Node.js plante en raison d'une erreur, elle redémarrera et si Ubuntu se bloque pour une raison quelconque, le processus redémarrera automatiquement avec Ubuntu. Les processus peuvent être redémarrés avec pm2 gracefulReload all
et Process Manager 2 peut être redémarré avec pm2 update
. Pour empêcher Process Manager 2 de démarrer au démarrage, exécutez pm2 unstartup
.
Essai
Essayez de taper reboot
et de vérifier si votre application est servie après le démarrage d'Ubuntu. Si l'application est destinée au Web et servie via le port 80
, curl http://localhost/
le code HTML de la page de démarrage s'affiche. Dans le cas où cela ne fonctionne pas, la commande pm2 status
affichera les processus en cours d'exécution et la commande de démarrage peut être réémise.
Déploiement de nouvelles versions de l'application
Si l'application est mise à jour, par exemple en tirant un référentiel git, une commande doit être émise pour mettre à jour les processus d'application en cours d'exécution.
$ pm2 update
Exemple d'utilisation
Parse Server , une plate-forme open source populaire en tant que service, sert de backend pour une application. Le backend peut se bloquer en raison d'erreurs dans le code ou le volume de demandes, mais l'application ne subira aucun temps d'arrêt car les autres serveurs (et / ou processus) continuent de s'exécuter et le processus Parse Server est rapidement redémarré.