Le applicazioni Node.js sono famose per la loro capacità di ridimensionamento. L'esecuzione di più processi simultanei su più server produce una latenza inferiore e un tempo di attività maggiore. Quando si gestiscono più server, è più semplice riavviare automaticamente le applicazioni Node.js in caso di arresto anomalo. Questo tutorial ti mostrerà come impostare rapidamente la persistenza dell'applicazione da un'istanza di Ubuntu 16.04 vuota.
Prerequisiti
- Crea un'istanza Vultr di qualsiasi dimensione con Ubuntu 16.04 LTS x64.
- Se non sei l'utente root, esegui
sudo -s
e digita la password. Per modificare il file di avvio è necessario l'accesso root in modo che il gestore processi si avvii all'avvio.
- Assicurarsi che Node.js sia installato sull'istanza e che la versione di Node.js sia 8.9.3 LTS o successiva, necessaria per il corretto funzionamento del gestore di persistenza. Utilizzare
node -v
per verificare la versione installata. Se Node.js non è sulla versione corretta, verranno installati i seguenti comandi.
Installa Node.js.
$ sudo apt-get update
$ curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash -
$ sudo apt-get install -y nodejs
Crea partizione di swap
Questo passaggio è facoltativo, ma consigliato per l'installazione. Le partizioni di swap sono porzioni del disco rigido dedicate a integrare la RAM. Su istanze Vultr più piccole, come l'istanza RAM da 512 MB, la creazione di una partizione di swap sarebbe vantaggiosa per le prestazioni. Per una versione automatizzata dell'esercitazione di scambio, utilizzare i comandi seguenti.
$ git clone https://github.com/teamtofu/server-tools.git tools
$ bash ./tools/swap.sh
In generale, l'utilizzo di swap non sarebbe necessario per istanze con almeno 4 GB di RAM durante l'impostazione di applicazioni persistenti, sebbene possa migliorare le prestazioni delle applicazioni. La RAM è più reattiva dello swap, quindi le istanze con più RAM tenderanno a produrre risultati migliori indipendentemente dallo swap.
Installa filato
Yarn è un gestore di pacchetti facile da usare da Facebook per i pacchetti Node.js. È più veloce di NPM e anche deterministico, il che è particolarmente utile quando si distribuiscono più server.
$ 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
Tuttavia, NPM può essere utilizzato al posto di Yarn e presenta comandi comparabili a tutti quelli presenti in questo tutorial.
Installa la tua applicazione Node.js
Se la tua applicazione è ospitata in un repository git, clonala e usa yarn install
. L'applicazione dovrebbe avere un file di accesso al server, in genere server.js
o index.js
, che verrà utilizzato nei passaggi successivi.
Installa Process Manager 2
Process Manager 2 è il pacchetto che riavvierà automaticamente l'applicazione. Process Manager 2 è molto popolare ed è utilizzato da Microsoft, PayPal e Intuit, quindi è sicuro e affidabile.
$ yarn global add pm2
Aggiungi la tua domanda come processo
L'applicazione verrà demonizzata (eseguita in background) e riavviata automaticamente con il comando start.
$ pm2 start [path to your entry.js] -i max
Se si desidera avviare automaticamente il numero massimo di processi, passare l' -i max
argomento. Se il solo uso di questa istanza di Vultr è di servire l'applicazione, questo è raccomandato. Per le istanze Vultr con più di una CPU, verranno avviati più processi e Process Manager 2 fungerà da bilanciamento del carico per tutti questi singoli processi.
Avvia automaticamente l'applicazione all'avvio
Dopo aver avviato l'app, salva la configurazione dell'applicazione. Quindi, esegui il comando di avvio per eseguire automaticamente Process Manager 2 in background all'avvio di Ubuntu. Per Ubuntu 16.04, Process Manager 2 si collegherà a systemd
.
$ pm2 save
$ pm2 startup
Ora se l'applicazione Node.js si arresta in modo anomalo a causa di un errore, verrà riavviata e se Ubuntu si arresta in modo anomalo per qualsiasi motivo, il processo si riavvierà automaticamente con Ubuntu. I processi possono essere riavviati con pm2 gracefulReload all
e Process Manager 2 può essere riavviato con pm2 update
. Per interrompere l'avvio di Process Manager 2, eseguire pm2 unstartup
.
analisi
Prova a digitare reboot
e controllare per vedere se l'applicazione viene pubblicata dopo l'avvio di Ubuntu. Se l'applicazione è per il Web e viene pubblicata sulla porta 80
, curl http://localhost/
mostrerà l'HTML per la pagina iniziale. Nel caso in cui non funzioni, il comando pm2 status
mostrerà i processi in esecuzione e il comando di avvio può essere riemesso.
Distribuzione di nuove versioni dell'applicazione
Se l'applicazione viene aggiornata, ad esempio estraendo un repository git, è necessario emettere un comando per aggiornare i processi dell'applicazione in esecuzione.
$ pm2 update
Esempio di utilizzo
Parse Server , una popolare piattaforma open source come servizio, funge da back-end per un'applicazione. Il back-end potrebbe bloccarsi a causa di errori nel codice o nel volume delle richieste, ma l'applicazione non subirà tempi di inattività poiché gli altri server (e / o processi) continuano a essere eseguiti e il processo Parse Server viene riavviato rapidamente.