AWS Basic
- AWS Intro
- Launch EC2 Instance
- Elastic IP
- AWS Target Group
- AWS Application Load Balancer
- AWS Route53
- Amazon Certificate Manager
- Redirect HTTP to HTTPs
- Redirect WWW to Non WWW
- AWS Cloudfront
- Download S3 to Local
- Install Node.js & NPM in EC2
AWS Connection
AWS Wordpress
AWS Deploy App
Deploy Node.js Website on an EC2 Instance
Photo Credit to CodeToFun
🙋 Introduction
In the vast landscape of web development, deploying a Node.js website on a cloud server is a common and essential task.
Amazon Elastic Compute Cloud (EC2) provides a scalable cloud computing solution, allowing developers to easily deploy and manage applications.
In this tutorial, we'll walk through the steps of deploying a Node.js website on an EC2 instance.
📚 Prerequisites
Before we begin, make sure you have the following prerequisites:
AWS Account and EC2 Access:
Ensure you have an AWS account with access to the EC2 service.
Running EC2 Instance:
Make sure you have an EC2 instance that is up and running.
Elastic IP Association:
Associate an Elastic IP with your EC2 instance to provide a static IP address.
File Transfer with Filezilla:
Set up Filezilla with a connection to your EC2 instance for easy file transfer.
Secure Shell Access with PuTTY:
Configure PuTTY to establish a secure shell connection to your EC2 instance.
Node.js and NPM Installation:
Ensure Node.js and NPM are installed on your EC2 instance for running your Node.js application.
🖥️ Creating a Simple Node.js App
Let's develop a straightforward Node.js web application that comprises two files: the index.js, and a hello-world.html files.
Here the index.js is the core node.js file
const http = require('http');
const fs = require('fs');
const path = require('path');
const server = http.createServer((req, res) => {
// Handling the root ("/") route
if (req.url === '/') {
res.writeHead(200, { 'Content-Type': 'text/plain' });
res.end('Hello, this is the root!');
}
// Handling the "/hello-word" route
else if (req.url === '/hello-world') {
const filePath = path.join(__dirname, 'hello.html');
// Reading the HTML file
fs.readFile(filePath, 'utf8', (err, data) => {
if (err) {
res.writeHead(500, { 'Content-Type': 'text/plain' });
res.end('Internal Server Error');
} else {
res.writeHead(200, { 'Content-Type': 'text/html' });
res.end(data);
}
});
}
// Handling other routes
else {
res.writeHead(404, { 'Content-Type': 'text/plain' });
res.end('404 Not Found');
}
});
const PORT = 80;
server.listen(PORT, () => {
console.log(`Server running at http://localhost:${PORT}/`);
});
Create a sample page named hello-world.html, and utilize node.js to serve this page when a GET request for '/hello-world' is made.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Hello World</title>
</head>
<body>
<h1>Hello, World!</h1>
<p>This is the hello.html file served by Node.js.</p>
</body>
</html>
🚀 Launching an EC2 Instance
After completing the prerequisites, proceed with the following steps to deploy your Node.js application on an EC2 instance.
Make sure that your EC2 instance is operational and running.
Photo Credit to CodeToFun
Establish a connection to the EC2 instance using PuTTY.
Photo Credit to CodeToFun
Make sure that Node.js and npm are installed on your Amazon Ubuntu Instance.
Photo Credit to CodeToFun
Create a directory on your Amazon Ubuntu EC2 instance with the provided command.
sudo mkdir nodejs-website
Photo Credit to CodeToFun
Grant permission to the directory to enable file uploads.
Before granting permission, the directory name appears in blue color with transparent background.
After granting permission, the directory name appears in blue color with green background.
Run the following command to grant permission.
sudo chmod 777 /home/ubuntu/nodejs-website
Photo Credit to CodeToFun
Transfer your website files and folders from your local machine to an EC2 instance using Filezilla.
Photo Credit to CodeToFun
Next, use PuTTY to globally install PM2. Use the following command to install PM2.
sudo npm i -g pm2
Photo Credit to CodeToFun
Navigate to the website directory and initiate the application with pm2 by executing the following command:
sudo pm2 start index.js
Photo Credit to CodeToFun
Congratulations! We have successfully initiated our Node.js application using pm2. You can now close PuTTY.
Proceed to step 1, where you should copy the Public IPv4 DNS or Public IPv4 address, then paste it into the URL and press Enter.
Photo Credit to CodeToFun
Our Node.js application is running successfully on our Amazon Ubuntu EC2 instance.
🎉 Conclusion
Congratulations! You've successfully deployed a Node.js website on an EC2 instance. Remember to monitor your application, set up security measures, and consider using a domain name for a production environment.
👨💻 Join our Community:
Author
For over eight years, I worked as a full-stack web developer. Now, I have chosen my profession as a full-time blogger at codetofun.com.
Buy me a coffee to make codetofun.com free for everyone.
Buy me a Coffee
If you have any doubts regarding this article (Deploy Node.js Website on an EC2 Instance), please comment here. I will help you immediately.