How to install and configure Node.js on managed hosting accounts

This article describes how to install the Node.js platform on managed VPS hosting accounts (please see the Article Details sidebar to the right for a complete list of supported products). You can use Node.js to host third-party applications or you can run your own applications.

The procedures in this article are unsupported. Instead, cPanel now includes the Node.js Selector (with the exception of managed VPS accounts,) which greatly simplifies installing and configuring Node.js applications. For information about how to use the Node.js Selector, please see this article.

Installation prerequisites

Your account must have the normal shell (not jailshell) enabled. To determine which shell your account is using, log in using SSH, and then type the following command:

echo $SHELL

If your account is using jailshell, please open a support ticket on the Customer Portal at https://my.a2hosting.com and request normal shell access for your account.

Installing Node.js and npm

After you determine that your account meets the installation prerequisites, you can download and install Node.js and npm (the Node.js package manager). To do this, follow these steps:

  1. Log in to your account using SSH.
  2. At the command prompt, type the following commands:
    cd ~
    wget https://nodejs.org/dist/v16.20.2/node-v16.20.2-linux-x64.tar.xz
    • This command downloads the binaries for the Node.js version 16.20.2 LTS (long-term support) release. If you download a newer development version of Node.js, change the version numbers in the following commands to match the version you downloaded.
    • Although there are more recent LTS versions such as 18.19.0 and 20.11.0, they require higher versions of the GNU C library (glibc) than what is currently installed on our managed servers.
  3. To extract the Node.js files, type the following command:

    tar xvf node-v16.20.2-linux-x64.tar.xz
    
  4. To rename the extracted folder to the more convenient nodejs name, type the following command:

    mv node-v16.20.2-linux-x64 nodejs
    
  5. To install the node and npm binaries, type the following commands:

    mkdir ~/bin
    cp nodejs/bin/node ~/bin
    cd ~/bin
    ln -s ../nodejs/lib/node_modules/npm/bin/npm-cli.js npm
    

    After you run these commands, Node.js and npm are installed on your account. To verify this, type the following commands:

    node --version
    npm --version
    
    The ~/bin directory is in your path by default, which means you can run node and npm from any directory in your account.

Starting a Node.js application

After you install Node.js, you are ready to run Node.js applications. However, the exact steps to do this vary depending on the application configuration.

Method #1: Use npm

Many third-party and “production-ready” applications (such as Ghost) use the npm program to start the application, as shown by the following command:

nohup npm start --production &
The & places the command in the background, and the nohup command ensures that the application continues running even if you log out of the current terminal session.

For this method to work, there must be a valid package.json file for the application. The package.json file contains project metadata that the npm program reads to determine how to start the application, manage its dependencies, and more.

To view the official npm documentation for the package.json file, please visit https://docs.npmjs.com/files/package.json.
Method #2: Run node directly

For simple applications, or for any application that does not have a package.json file, you can run the node executable directly and specify the application filename. For example:

nohup node my_app.js &

However, you lose the benefits of using npm to manage the application.

As above, the & places the command in the background, and the nohup command ensures that the application continues running even if you log out of the current terminal session.

Stopping a Node.js application

To stop a currently running Node.js application, type the following command:

pkill node

This command immediately stops all running Node.js applications.

Integrating a Node.js application with the web server

Depending on the type of Node.js application you are running, you may want to be able to access it using a web browser. To do this, you need to select an unused port for the Node.js application to listen on, and then define server rewrite rules that redirect visitors to the application. The following steps demonstrate how to do this:

  1. In a text editor, add the following lines to the .htaccess file in the /home/username/public_html directory, where username represents your account username:
    DirectoryIndex disabled
    RewriteEngine On
    RewriteRule ^$ http://127.0.0.1:XXXXX/ [P,L]
    RewriteCond %{REQUEST_FILENAME} !-f
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteRule ^(.*)$ http://127.0.0.1:XXXXX/$1 [P,L]
    These rewrite rules redirect incoming HTTP visitor requests to the Node.js application running locally on the server. 127.0.0.1 is the loopback address for localhost.
  2. In both RewriteRule lines, replace XXXXX with the port on which your Node.js application listens.

    To run a Node.js application on a managed server, you must select an unused port between 30000 and 50000 (inclusive).
  3. Save the changes to the .htaccess file, and then exit the text editor. Visitors to your web site are redirected to the Node.js application listening on the specified port.

    If your application fails to start, the port you chose may already be in use. Check the application log for error codes like EADDRINUSE that indicate the port is in use. If it is, select a different port number, update your application's configuration and the .htaccess file, and then try again.

More Information

For more information about Node.js, please visit http://nodejs.org.

Did you find this article helpful? Then you'll love our support. Experience the A2 Hosting difference today and get a pre-secured, pre-optimized website. Check out our web hosting plans today.

We use cookies to personalize the website for you and to analyze the use of our website. You consent to this by clicking on "I consent" or by continuing your use of this website. Further information about cookies can be found in our Privacy Policy.