Detailed explanation of nginx front-end distribution method based on $remote_addr

Detailed explanation of nginx front-end distribution method based on $remote_addr

The requirements are as follows:

There are multiple servers under the domain name. Now we are testing a certain region. Let the IP users in a certain region access only one server and test it separately. If there is no problem, all servers will be updated. If there is a problem, the impact will be small. We will find and solve the problem in time.

Solution:

Use the nginx module to configure matching rules on the front-end load balancing forwarding machine;

In the nginx configuration vhost, add a piece of code to the location section under the domain name

If $remote_addr matches the ip, forward it to abc_test_server;

server {
  listen 80;
  server_name abc.com.cn;
  access_log /dev/null;
  error_log /data/logs/error.log;
  
  location / {

  proxy_set_header Host $host;
  proxy_set_header X-Real-IP $remote_addr;
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      if ($remote_addr ~ "202.96.134.100") 
       {
           proxy_pass http://abc_test_server;
            break;
        }
  proxy_pass http://abc_server;
  }
}

The load balancing configuration also needs to add a section

#abc_test only
upstream abc_test_server {
  server 192.168.20.10:80;
  
}

#abc.com.cn
upstream abc_server {
  server 192.168.20.11:80;
  server 192.168.20.12:80;
  server 192.168.20.13:80;
}

The set IP will be directly distributed to the backend server 192.168.20.10 for testing;

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • Detailed explanation of Nginx configuration required for front-end
  • How to use Nginx to solve front-end cross-domain problems
  • Nginx configuration for front-end development (scenario)
  • Several methods of deploying multiple front-end projects with nginx
  • Detailed explanation of how Nginx solves the problem of cross-domain access to front-end resources
  • Detailed explanation of what nginx can do on the front end

<<:  Node+express to achieve paging effect

>>:  MySQL Server 8.0.13.0 Installation Tutorial with Pictures and Text

Recommend

How to configure the My.ini file when installing MySQL5.6.17 database

I recently used the MySql database when developin...

Detailed explanation of SSH password-free login configuration under Linux

Assume there are two Linux servers A and B, and w...

HTML implements a fixed floating semi-transparent search box on mobile

Question. In the mobile shopping mall system, we ...

HTML tag full name and function introduction

Alphabetical DTD: Indicates in which XHTML 1.0 DT...

MySQL transaction details

Table of contents Introduction Four characteristi...

Examples of using HTML list tags dl, ul, ol

Copy code The code is as follows: <!-- List ta...

The implementation principle of Mysql master-slave synchronization

1. What is MySQL master-slave synchronization? Wh...

HTML implementation of a simple calculator with detailed ideas

Copy code The code is as follows: <!DOCTYPE ht...

React Hooks Usage Examples

Table of contents A simple component example More...

How are spaces represented in HTML (what do they mean)?

In web development, you often encounter characters...

Example of using JS to determine whether an element is an array

Here are the types of data that can be verified l...

CSS and HTML and front-end technology layer diagram

The relationship between Javascript and DOM is ve...