Teach you how to deploy NGINX and PM2 on a VPS server

WBOY
Release: 2023-09-27 13:25:02
Original
1039 people have browsed it

Teach you how to deploy NGINX and PM2 on a VPS server

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.

  1. Installing NGINX:

First, we need to install NGINX as our web server.

1.1 Update apt-get package management tool:

sudo apt-get update
Copy after login

1.2 Install NGINX:

sudo apt-get install nginx
Copy after login

Configuration file location: /etc/nginx/nginx.conf.

  1. Configure NGINX:

2.1 Create a new site configuration file:

sudo nano /etc/nginx/sites-available/myapp
Copy after login

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;
  }
}
Copy after login

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/
Copy after login
  1. Install PM2:

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
Copy after login

3.2 Start your application:

pm2 start app.js
Copy after login

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
Copy after login

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.

  1. Configure NGINX reverse proxy:

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
Copy after login

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;
    }
  }
  ...
}
Copy after login

Note: Replace "your_domain.com" with your domain name, "http:// localhost:3000" with your application address.

  1. Restart NGINX and PM2:

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
Copy after login

5.2 Restart PM2:

pm2 restart all
Copy after login

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!

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template