Prerequisites
Hosted Linux server
Project on git
Many Hosting services provide a Linux server to host the application. Amazon(EC2), and Linode are some popular hosted servers.
This tutorial is based on Ubuntu OS on the hosted Linux server, though procedures are almost similar for other distros of Linux.
We can log in to the Linux server using SSH(Secure Shell). From a Windows machine, we can use the PuTTY client for the connection and from Linux based system we can use the terminal.
ssh ubuntu@<your_ip_address>
Replace <your_ip_address>
with the IP of your VPS
First of all, run an update on the Ubuntu server.
sudo apt update
Install Node.Js on VPS
curl -sL https://deb.nodesource.com/setup_18.x -o nodesource_setup.sh
sudo bash nodesource_setup.sh
Install npm, next, pm2 and nginx
sudo apt install -g npm
sudo apt install -g next
sudo npm install -g pm2
git clone your_repository_url project_name
It will clone the project inside the folder called project_name
For deployment purposes, we generally use the build files. So we need to generate the build folder
cd project_name
npm install --legacy-peer-deps
npm run build
A build folder is generated in the project directory it could be either .next
or build
which will be mentioned in the project configuration
pm2 start npm --name "your-project-name" -- start
Now your project should be running on the server’s 3000
port.
To check the log of the project use the following command
pm2 log your-project-name
cd /etc/nginx/conf.d
nano yourdomain.conf
On the nano text editor paste the following script at the end of the file. (Replace yourdomain.com
with your original domain)
map $http_upgrade $connection_upgrade {
default upgrade;
'' close;
}
server {
server_name yourdomain.com www.yourdomain.com;
location / {
# Next.js project
proxy_pass http://127.0.0.1:3000;
proxy_http_version 1.1;
proxy_set_header Host $host;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;
}
}
Save the file
After this check the script and restart the Nginx server
sudo nginx -t
sudo systemctl restart nginx
Update the DNS A record of your domain to redirect to server IP and after some time visit http://yourdomain.com
, you can find your site hosted.
Now we will install the SSL certificate for the site. We are using the Let’s Encrypt certificate provider.
cd ~
sudo apt install certbot python3-certbot-nginx
certbot --nginx -d yourdomain.com -d www.yourdomain.com
If successfully installed you will see the congratulatory message and you will find the certificate on /etc/letsencrypt/live/yourdomain.com/
Visiting /etc/nginx/conf.d/yourdomain.conf
file, You will see the HTTPS rules automatically added to the configuration.
Now restart the Nginx server
sudo systemctl restart nginx
Now visit the sitehttps://yourdomain.com
Congratulations, you have successfully deployed Next.JS using PM2 along with an SSL certificate.
Discover Dallo Tech, a leading software development company offering expertise in Mobile and Web App Development, Data Analytics, Visualization, AI, and Blockchain solutions. Elevate your digital journey with our innovative technology services.
Sun - Fri:
10:00 am - 5:00 pm
Saturday:
CLOSED