Teach you how to deploy NGINX and PM2 on a VPS server
Foreword:
The deployment of a VPS server is one of the key steps for a website or application. Here, I will introduce to you how to deploy NGINX and PM2 on a VPS server. These two tools can greatly improve the performance and stability of the website. This article will introduce the installation and configuration process in detail and provide specific code examples.
First, we need to install NGINX as our web server.
1.1 Update apt-get package management tool:
sudo apt-get update
1.2 Install NGINX:
sudo apt-get install nginx
Configuration file location: /etc/nginx/nginx.conf
.
2.1 Create a new site configuration file:
sudo nano /etc/nginx/sites-available/myapp
2.2 In the file, enter the following:
server { listen 80; server_name your_domain.com; location / { proxy_set_header X-Real-IP $remote_addr; proxy_set_header Host $host; proxy_pass http://localhost:3000; } }
Note: Replace "your_domain.com" with your domain name and "http://localhost:3000" with the address of your actual application.
2.3 Save and exit the file: Press Ctrl X
, then enter Y
to save changes.
2.4 Create a symbolic link:
sudo ln -s /etc/nginx/sites-available/myapp /etc/nginx/sites-enabled/
PM2 is a Node.js process management tool that ensures your Applications continue to run on the server and can recover from failures.
3.1 Install PM2:
sudo npm install -g pm2
3.2 Start your application:
pm2 start app.js
Note: app.js
is the entry file of your application , you need to replace it with your own filename.
3.3 Generate startup script:
pm2 startup systemd
After running this command, you will see a prompt, copy the command it gives into the terminal and run it. This will create a service for PM2 to run automatically on system reboot.
Now, we need to configure NGINX to forward all traffic to applications launched by PM2.
4.1 Open the NGINX configuration file:
sudo nano /etc/nginx/nginx.conf
4.2 Modify the configuration file:
http{ ... server { listen 80; server_name your_domain.com; location / { proxy_set_header X-Real-IP $remote_addr; proxy_set_header Host $host; proxy_pass http://localhost:3000; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection 'upgrade'; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_cache_bypass $http_upgrade; } } ... }
Note: Replace "your_domain.com" with your domain name, "http:// localhost:3000" with your application address.
After completing the above configuration, we need to restart NGINX and PM2 for the changes to take effect.
5.1 Restart NGINX:
sudo systemctl restart nginx
5.2 Restart PM2:
pm2 restart all
At this point, we have successfully deployed NGINX and PM2 on the VPS server. NGINX acts as a reverse proxy and forwards all traffic to applications started by PM2, thus improving the performance and stability of the website. In the future development and maintenance process, you can use other functions of PM2, such as log management and monitoring.
Summary:
This article details how to deploy NGINX and PM2 on a VPS server and provides specific code examples. These tools can help you improve the performance and stability of your website and are essential tools in the website deployment process. I hope this article can help you and make your website better!
The above is the detailed content of Teach you how to deploy NGINX and PM2 on a VPS server. For more information, please follow other related articles on the PHP Chinese website!