How to configure multiple projects with the same domain name in Nginx

How to configure multiple projects with the same domain name in Nginx

There are two ways to configure multiple projects under the same domain name using Nginx:

  • nginx is distributed to different projects according to different directories
  • Enable the second-level domain name, and assign different second-level domain names to different projects

1. nginx is distributed to different projects according to different directories:

server {
  listen 80;
  server_name example.com;
 
  location ^~ /project1 {
    proxy_pass http://localhost:8081;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }
 
  location ^~ /project2 {
    proxy_pass http://localhost:8082;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }
 
  location / {
    proxy_pass http://localhost:8080;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }
}

Three projects are configured here:

  • http://example.com/project1 is distributed to http://localhost:8081
  • The path http://example.com/project2 is distributed to http://localhost:8082
  • Other paths are distributed to http://localhost:8080

2. Enable the second-level domain name, and assign different second-level domain names to different projects

Note: Many students say it is invalid because you must first add an A record to the secondary domain name to the host. The same domain name can add N secondary domain names to the same host.

server {
  listen 80;
  server_name example.com;
  location / {
    proxy_pass http://localhost:8080;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }
}

project1

server {
  listen 80;
  server_name project1.example.com;
  location / {
    proxy_pass http://localhost:8081;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }
}

project2

server {
  listen 80;
  server_name project2.example.com;
  location / {
    proxy_pass http://localhost:8082;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  }
}

Note: These three projects belong to different domain names, and there will be cross-domain issues when accessing projects via http.

This is the end of this article about how to configure multiple projects with the same domain name in Nginx. For more information about configuring multiple projects with the same domain name in Nginx, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Complete steps for Nginx proxy front-end and back-end separation projects with the same domain name
  • How to deploy multiple Vue projects under the same domain name using nginx and use reverse proxy

<<:  Example of using CSS3 to customize the style of input multiple-select box

>>:  Collapsed table row element bug

Recommend

How to solve the high concurrency problem in MySQL database

Preface We all know that startups initially use m...

Detailed explanation of MySQL combined index method

For any DBMS, indexes are the most important fact...

Detailed steps to install Anaconda on Linux (Ubuntu 18.04)

Anaconda is the most popular python data science ...

Detailed explanation of how to pass password to ssh/scp command in bash script

Install SSHPASS For most recent operating systems...

How to backup and restore the mysql database if it is too large

Command: mysqlhotcopy This command will lock the ...

Summary of essential knowledge points for MySQL query optimization

Preface Query optimization is not something that ...

React + Threejs + Swiper complete code to achieve panoramic effect

Let’s take a look at the panoramic view effect: D...

Security considerations for Windows server management

Web Server 1. The web server turns off unnecessar...

iframe parameters with instructions and examples

<iframe src=”test.jsp” width=”100″ height=”50″...

Detailed explanation of how components communicate in React

1. What is We can split the communication between...

Detailed explanation of the correct way to install opencv on ubuntu

This article describes how to install opencv with...

jQuery implements sliding tab

This article example shares the specific code of ...

About converting textarea text to html, that is, carriage return and line break

Description: Change the carriage return in the tex...