Nginx 配置根据请求IP末段进行分流的方法
主要是location参数中的if判断的配置跳转,分流能减轻服务器的负载和压力,这种是一种非常常见的服务器部署架构。
根据IP最后一段的范围来跳转
#域名,ip,端口等信息请自行修改 upstreamhuaji-01.com{ server192.168.1.100:8080; } upstreamhuaji-02.com{ server192.168.1.200:8080; } server{ listen80; server_namewww.huaji.com; location/ { if($remote_addr~*^(.*)\.(.*)\.(.*)\.[1,125]$){ proxy_passhttp://huaji-01.com; break; } proxy_passhttp://huaji-02.com; } }
以上为将IP末段为1-125的请求来源转发到huaji-01.com,其他转向huaji-02.com,同样可以修改正则,例如
规则:$remote_addr~*^(.*)\.(.*)\.(.*)\.*[0268]$末尾为0268这样的偶数ip,跳转到huaji-01.com,其他跳转到第二个域名;
规则:$remote_addr~*^(112)\.(.*)\.(.*)\.(.*)$开头为112的IP跳转到指定的域名;
规则:$http_x_forwarded_for~*^(112)\.(.*)\.(.*)\.(.*)$根据forward地址段来分流,开头为112的跳转到指定域名
if指令条件判断的含义:
正则表达式匹配,其中:
~为区分大小写匹配
~*为不区分大小写匹配
!~和!~*分别为区分大小写不匹配及不区分大小写不匹配
文件及目录匹配,其中:
-f和!-f用来判断是否存在文件
-d和!-d用来判断是否存在目录
-e和!-e用来判断是否存在文件或目录
-x和!-x用来判断文件是否可执行
rewrite指令的最后一项参数为flag标记,flag标记有:
last相当于apache里面的[L]标记,表示rewrite。
break本条规则匹配完成后,终止匹配,不再匹配后面的规则。
redirect返回302临时重定向,浏览器地址会显示跳转后的URL地址。
permanent返回301永久重定向,浏览器地址会显示跳转后的URL地址。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。