Tutorial

How To Host Multiple Node.js Applications On a Single VPS with nginx, forever, and crontab

Published on September 5, 2013
author

Christian Fei

How To Host Multiple Node.js Applications On a Single VPS with nginx, forever, and crontab

Requirements to Follow This Tutorial


You need to have nginx and Node.js installed, and there are already well written tutorials about these topics on DigitalOcean:

How to install nginx and How to install Node.js.

In addition, you should already own a domain, in order to map a running Node.js service to a domain name, instead of navigating to http://[your-vps-ip]:[port].

Running Your Node.js Application with Forever


Forever is a simple command line tool for ensuring that a Node.js application runs continuously (i.e. forever). This means if your app encounters an error and crashes, forever will take care of this issue and restart it for you.

Simply install forever globally and forever can be used in a matter of seconds:

npm install forever -g

To start a script with forever you need to follow these steps:

Navigate to your Node.js application:

cd /path/to/your/node/app/

and run the server/main JavaScript file with forever:

forever start --spinSleepTime 10000 main.js

Where --spinSleepTime 10000 refers to the minimum uptime (in milliseconds) between launches of a crashing script. This command will work for almost all cases.

Now point your browser to http://[your-vps-ip]:[port] and see your app running.

Map a Domain To Your Node.js Application


Now you’ll need to add a DNS record in your DigitalOcean control panel to map your domain name to your droplet (VPS).

The steps to follow are:<ol> <li>Login at DigitalOcean.com</li> <li>Click on the ‘DNS’ section in the left sidebar</li> <li>Add a domain by clicking on the ‘Add Domain’ button, select your VPS of choice and enter the domain name you registered in the ‘Name’ field</li> <li>Copy the Nameservers provided by DigitalOcean (e.g. NS1.DIGITALOCEAN.COM.) and add each one to the DNS records in the control panel of your domain registrar.</li></ol>

Note: changes will not be immediate, since DNS can take up to 24 hours to propagate.

Map a Domain To a Service Running on Your VPS with nginx


In this section, you’ll learn how to set up a reverse proxy with nginx in a few simple steps.

First of all, create a file for your desired domain in /etc/nginx/conf.d/ with your favorite editor (I’ll use nano). The file should be named after the domain name, for consistency reasons.

nano /etc/nginx/conf.d/example.com.conf

Note: you can call the file whatever you want, the important part is the .conf extension.

In this file, you’ll want to copy the following code snippet and paste it in the file created before:

server {
    listen 80;

    server_name your-domain.com;

    location / {
        proxy_pass http://localhost:{YOUR_PORT};
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection 'upgrade';
        proxy_set_header Host $host;
        proxy_cache_bypass $http_upgrade;
    }
}

Now simply replace your-domain.com with the domain you have registered and YOUR_PORT with the port your Node.js app is listening to on your VPS.

Note: to be able to reference multiple domains for one Node.js app (like www.example.com and example.com) you need to add the following code to the file /etc/nginx/nginx.conf in the http section:

server_names_hash_bucket_size 64;

If the DNS changes are propagated, you can point your web browser to your domain and you should see your application running, accessible from the internet.

Restarting Your Node.js App at Reboot


Forever is good when it comes to keeping your application running when it crashes etc. but what happens when the VPS gets rebooted?

This is where a simple cronjob can prevent your application and your users from unexpected downtimes.

Create a file called starter.sh in your application’s home folder and copy the following code:

#!/bin/sh

if [ $(ps -e -o uid,cmd | grep $UID | grep node | grep -v grep | wc -l | tr -s "\n") -eq 0 ]
then
        export PATH=/usr/local/bin:$PATH
        forever start --sourceDir /path/to/your/node/app main.js >> /path/to/log.txt 2>&1
fi

where main.js should be replaced with your application’s main script.

This useful snippet has been taken from here

To start this script at each reboot you need to edit the crontab with this command:

crontab -e

and append the following code to this file

@reboot /path/to/starter.sh

Now set the absolute path to your starter.sh file.

Tip: Navigate where your starter.sh file is located and print the current directory with pwd.

Repeat the steps above for each of your domains/services.

<div class=“author”>Submitted by: <a href=“https://twitter.com/christian_fei”>Christian Fei</a></div>

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
Christian Fei

author

Still looking for an answer?

Ask a questionSearch for more help

Was this helpful?
 
10 Comments


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!

typo at /etc/nginc/nginx.conf

also, in order for starter.sh to work on reboot, I had to run chmod +x starter.sh

thanks for the guide!

Also, forever should be run from an app’s directory so that the base directory may be used from the node script. Many developers will use the app’s base directory to read files. Otherwise, the node script will error out.

Improved starter.sh with relative path here: https://gist.github.com/danro/6533818

Kamal Nasser
DigitalOcean Employee
DigitalOcean Employee badge
September 12, 2013

@dan: You can just pass <pre>–sourceDir /path/to/app</pre> instead. I’ve updated the article.

@Kamal good point, thanks!

The path /etc/nginc/nginx.conf seems wrong, should be /etc/nginx/nginx.conf.

Inside starter.sh the node file is “test.js”. But in the next line the same file is described as “main.js”. Is that right?

Kamal Nasser
DigitalOcean Employee
DigitalOcean Employee badge
October 1, 2013

@maxcnunes: Nice catch! I’ve updated the article. Thanks!

my domain still points to the ngix welcome page after falling all of these steps. Anyone available to help? thanks!

Kamal Nasser
DigitalOcean Employee
DigitalOcean Employee badge
October 12, 2013

@loranbriggs: Did you restart nginx? <code>sudo service nginx restart</code>

I did, then I tried nginx stop and then nginx start (both with sudo) and now I can’t start nginx at all.

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.