Nginx反向代理实现IP访问分流
通过Nginx做反向代理来实现分流,以减轻服务器的负载和压力是比较常见的一种服务器部署架构。本文将分享一个如何根据来路IP来进行分流的方法。
根据特定IP来实现分流
- 将IP地址的最后一段最后一位为0或2或6的转发至test-01.com来执行,否则转发至test-02.com来执行。
upstream test-01.com {
  server 192.168.1.100:8080;
}
upstream test-02.com {
  server 192.168.1.200:8080;
}
server {
  listen 80;
  server_name www.test.com;
  location / {
    if ( $remote_addr ~* ^(.*)\.(.*)\.(.*)\.*[026]$){
         proxy_pass http://test-01.com;
         break;
        }
        proxy_pass http://test-02.com;
    }
}
- 将IP地址前3段为192.168.202.*转发至test-01.com来执行,否则转发至test-02.com来执行。
upstream test-01.com {
  server 192.168.1.100:8080;
}
upstream test-02.com {
  server 192.168.1.200:8080;
}
server {
  listen 80;
  server_name www.test.com;
  location / {
        if ( $remote_addr ~* ^(192)\.(168)\.(202)\.(.*)$) {
           proxy_pass http://test-01.com;
           break;
        }
        proxy_pass http://test-02.com;
   }
}
根据指定范围IP来实现分流
将IP地址的最后一段为1-100的转发至test-01.com来执行,否则转发至test-02.com执行。
upstream test-01.com {
  server 192.168.1.100:8080;
}
upstream test-02.com {
  server 192.168.1.200:8080;
}
server {
  listen 80;
  server_name www.test.com;
  location / {
     if ( $remote_addr ~* ^(.*)\.(.*)\.(.*)\.[1,100]$){
          proxy_pass http://test-01.com;
          break;
     }
     proxy_pass http://test-02.com;
  }
}
根据forwarded地址分流
将IP地址的第1段为212开头的访问转发至test-01.com来执行,否则转发至test-02.com执行。
upstream test-01.com {
  server 192.168.1.100:8080;
}
upstream test-02.com {
  server 192.168.1.200:8080;
}
server {
  listen 80;
  server_name www.test.com;
  location /  {
      if ( $http_x_forwarded_for ~* ^(212)\.(.*)\.(.*)\.(.*)$){
          proxy_pass http://test-01.com;
          break;
      }
      proxy_pass http://test-02.com;
  }
}
if指令的作用
if指令: 判断表达式的值是否为真(true), 如果为真则执行后面大括号中的内容。
以下是一些条件表达式的常用比较方法:
- 变量的完整比较可以使用=或!=操作符
- 部分匹配可以使用或*的正则表达式来表示
- ~表示区分大小写
- ~*表示不区分大小写(nginx与Nginx是一样的)
- !与!*是取反操作,也就是不匹配的意思
- 检查文件是否存在使用-f或!-f操作符
- 检查目录是否存在使用-d或!-d操作符
- 检查文件、目录或符号连接是否存在使用-e或!-e操作符
- 检查文件是否可执行使用-x或!-x操作符
- 正则表达式的部分匹配可以使用括号,匹配的部分在后面可以用$1~$9变量代替
来源 https://www.jianshu.com/p/4f30d94cb259
Nginx反向代理实现IP访问分流的更多相关文章
- Nginx反向代理的目录访问问题
		Nginx反向代理的目录访问问题 2013-05-13 23:21 2730人阅读 评论(0) 收藏 举报 从昨天就开始纠结了,在做实验的时候,遇到目录访问的问题,如下 前端nginx vhost的设 ... 
- nginx反向代理取得IP地址
		nginx反向代理后,在应用中取得的ip都是反向代理服务器的ip,取得的域名也是反向代理配置的url的域名,解决该问题,需要在nginx反向代理配置中添加一些配置信息,目的将客户端的真实ip和域名传递 ... 
- [亲测]ASP.NET Core 2.0怎么发布/部署到Ubuntu Linux服务器并配置Nginx反向代理实现域名访问
		前言 ASP.NET Core 2.0 怎么发布到Ubuntu服务器?又如何在服务器上配置使用ASP.NET Core网站绑定到指定的域名,让外网用户可以访问呢? 步骤 第1步:准备工作 一台Liun ... 
- [亲测]七步学会ASP.NET Core 2.0怎么发布/部署到Ubuntu Linux服务器并配置Nginx反向代理实现域名访问
		前言 ASP.NET Core 2.0 怎么发布到Ubuntu服务器?又如何在服务器上配置使用ASP.NET Core网站绑定到指定的域名,让外网用户可以访问呢? 步骤 第1步:准备工作 一台Liun ... 
- Nginx 反向代理,IP、端口,项目路径变化的问题
		这两天在云上部署公司项目,涉及到nginx反向代理,在部署完成测试,发现在下载文件的时候,无法下载,提示链接被拒绝. 假设nginx代理地址: http://121.53.21.188:9012/we ... 
- 通过Nginx反向代理实现IP分流
		通过Nginx做反向代理来实现分流,以减轻服务器的负载和压力是比较常见的一种服务器部署架构.本文将分享一个如何根据来路IP来进行分流的方法. 根据特定IP来实现分流 将IP地址的最后一段最后一位为0或 ... 
- Nginx 反向代理 一个IP代理多个域名,不区分端口,类似windows虚拟机。
		简介: IP有限,所以我们以前使用端口来区分不同的虚拟主机,提供不同的WEB服务. 小范围还凑活,一旦规模扩大,地址记不住了吧?端口记不住了吧? 这个时候我们可以使用DNS,域名解析,毕竟记名字比记I ... 
- nginx反向代理带路径访问问题
		nginx的配置为192.168.0.219:80分别映射到upstream组192.168.0.55:8080和192.168.0.206:8080,那如何配置做到访问192.168.0.219:8 ... 
- nginx反向代理时配置访问密码
		在有些情况下,我们需要对服务器上的某些资源进行限流或者禁止陌生人访问,我们可以通过nginx配置来对url添加访问密码. 效果如下 nginx 开启访问验证在 nginx 下,提供了 ngx_http ... 
随机推荐
- 【Scala篇】--Scala中的函数
			一.前述 Scala中的函数还是比较重要的,所以本文章把Scala中可能用到的函数列举如下,并做详细说明. 二.具体函数 1.Scala函数的定义 def fun (a: Int , b: Int ) ... 
- Python Matplotlib.pyplot plt 中文显示
			话不多说,上代码 # -*- coding: UTF-8 -*- import matplotlib.pyplot as plt from matplotlib.font_manager import ... 
- nginx替换响应头(重点:如何在替换时加上if判断)
			在实现微信小程序内嵌非业务域名时,通过nginx做镜像网站绕过小程序业务域名检测,但有一些表单页面提交后会返回一个302状态,由响应头Location的值决定提交成功后的跳转地址.那么问题来了,这个地 ... 
- 设计模式的征途—4.抽象工厂(Abstract Factory)模式
			上一篇的工厂方法模式引入了工厂等级结构,解决了在原来简单工厂模式中工厂类职责太重的原则,但是由于工厂方法模式的每个工厂只生产一类产品,可能会导致系统中存在大量的工厂类,从而增加系统开销.那么,我们应该 ... 
- asp.net core 系列 7 Razor框架路由(上)
			一.概述 在上二篇中,主要是介绍了asp.net core mvc中路由的使用,这篇继续介绍路由在ASP.NET Core Razor中的使用.Razor Pages应该使用默认的传统路由,从应用程序 ... 
- redis 系列12 哈希对象
			一. 哈希对象概述 Redis hash对象是一个string类型的field和value的映射表,hash特别适合用于存储对象.作为哈希对象的编码,有二种一是ziplist编码, 二是hashtab ... 
- Java多线程之Executor框架和手写简易的线程池
			目录 Java多线程之一线程及其基本使用 Java多线程之二(Synchronized) Java多线程之三volatile与等待通知机制示例 线程池 什么是线程池 线程池一种线程使用模式,线程池会维 ... 
- 一文读懂MapReduce
			Hadoop解决大规模数据分布式计算的方案是MapReduce.MapReduce既是一个编程模型,又是一个计算框架.也就是说,开发人员必须基于MapReduce编程模型进行编程开发,然后将程序通过M ... 
- 设计模式总结篇系列:单例模式(SingleTon)
			在Java设计模式中,单例模式相对来说算是比较简单的一种构建模式.适用的场景在于:对于定义的一个类,在整个应用程序执行期间只有唯一的一个实例对象.如Android中常见的Application对象. ... 
- C#线程安全使用(一)
			关于Task的使用,一直都是半知半解,最近终于有时间详细的看了一遍MSDN,作为备忘录,将心得也记录下来和大家分享. 首先,根据MSDN的描述,Task是FrameWork4引进的新功能,他和ConC ... 
