详解nginx前端根据$remote_addr分发方法
2020-05-07 04:05
106 查看
需求如下:
域名下面有多台服务器,现针对某个地区做测试,让某个地区的ip用户只访问某一台服务器,单独做测试,如果没问题,全部更新;有问题则影响较小,及时发现问题解决问题;
解决方案:
使用nginx的模块,在前端负载均衡转发的机器上,配置匹配规则;
nginx配置vhost里面,域名下面location段,增加一段代码
如果$remote_addr 匹配到ip的话,转发到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; } }
负载均衡配置也需要增加一段
#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; }
设定的ip会直接分发到192.168.20.10这一台后端服务器中,进行测试;
以上就是本文的全部内容,希望对大家的学习有所帮助
您可能感兴趣的文章:
相关文章推荐
- nginx前端根据$remote_addr分发方法 推荐
- nginx前端根据$remote_addr分发方法
- nginx根据$remote_addr分发 (客户端IP)
- nginx根据$remote_addr分发 nginx根据客户端IP分发
- 详解NGINX访问https跳转到http的解决方法
- 详解Nginx服务器中配置全站HTTPS安全连接的方法
- 详解Nginx服务器的配置中开启文件Gzip压缩的方法
- nginx变量使用方法详解(6)
- nginx做前端,后端web服务器无法获取真正客户机的ip,解决方法
- nginx变量使用方法详解(8)
- 用nginx做前端,后端apache能获得真实IP的方法
- 详解nginx rewrite和根据url参数location
- 详解 Nginx + Tomcat HTTPS/SSL 配置方法
- Nginx实现根据域名http、https分发配置示例
- 阿里云Linux系统Nginx配置多个域名的方法详解
- nginx变量使用方法详解(5)
- 详解Nginx服务器中配置超时时间的方法
- php根据分类合并数组的方法实例详解
- nginx变量使用方法详解(6)
- 详解Nginx http资源请求限制(三种方法)