nginx根据$remote_addr分发 (客户端IP)
2013-10-31 14:38
232 查看
server {
listen 80;
server_name www.abc.com;
location ~ ^(.*)\/\.svn\/{
deny all;
}
location /status {
stub_status on;
access_log off;
allow 172.16.10.0/24;
}
location / {
proxy_set_header Host www.abc.com;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
if ($remote_addr ~ "202.160.46.150|151") #如果有多个IP “(152|153|155)”
{
proxy_pass http://172.16.10.1:8000;
break;
}
proxy_pass http://172.16.10.2:8000;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
nginx location匹配规则
location匹配命令
~ #波浪线表示执行一个正则匹配,区分大小写
~* #表示执行一个正则匹配,不区分大小写
^~ #^~表示普通字符匹配,如果该选项匹配,只匹配该选项,不匹配别的选项,一般用来匹配目录
= #进行普通字符精确匹配
@ #"@" 定义一个命名的 location,使用在内部定向时,例如 error_page, try_files
=前缀的指令严格匹配这个查询。如果找到,停止搜索。
所有剩下的常规字符串,最长的匹配。如果这个匹配使用^〜前缀,搜索停止。
正则表达式,在配置文件中定义的顺序。
如果第3条规则产生匹配的话,结果被使用。否则,如同从第2条规则被使用。
location 匹配的优先级(与location在配置文件中的顺序无关)
= 精确匹配会第一个被处理。如果发现精确匹配,nginx停止搜索其他匹配。
普通字符匹配,正则表达式规则和长的块规则将被优先和查询匹配,也就是说如果该项匹配还需去看有没有正则表达式匹配和更长的匹配。
^~ 则只匹配该规则,nginx停止搜索其他匹配,否则nginx会继续处理其他location指令。
最后匹配理带有"~"和"~*"的指令,如果找到相应的匹配,则nginx停止搜索其他匹配;当没有正则表达式或者没有正则表达式被匹配的情况下,那么匹配程度最高的逐字匹配指令会被使用。
另附一个根据cookie分发 的案例:
http://blog.csdn.net/rabbit2003/article/details/6580217
listen 80;
server_name www.abc.com;
location ~ ^(.*)\/\.svn\/{
deny all;
}
location /status {
stub_status on;
access_log off;
allow 172.16.10.0/24;
}
location / {
proxy_set_header Host www.abc.com;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
if ($remote_addr ~ "202.160.46.150|151") #如果有多个IP “(152|153|155)”
{
proxy_pass http://172.16.10.1:8000;
break;
}
proxy_pass http://172.16.10.2:8000;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
}
nginx location匹配规则
location匹配命令
~ #波浪线表示执行一个正则匹配,区分大小写
~* #表示执行一个正则匹配,不区分大小写
^~ #^~表示普通字符匹配,如果该选项匹配,只匹配该选项,不匹配别的选项,一般用来匹配目录
= #进行普通字符精确匹配
@ #"@" 定义一个命名的 location,使用在内部定向时,例如 error_page, try_files
=前缀的指令严格匹配这个查询。如果找到,停止搜索。
所有剩下的常规字符串,最长的匹配。如果这个匹配使用^〜前缀,搜索停止。
正则表达式,在配置文件中定义的顺序。
如果第3条规则产生匹配的话,结果被使用。否则,如同从第2条规则被使用。
location 匹配的优先级(与location在配置文件中的顺序无关)
= 精确匹配会第一个被处理。如果发现精确匹配,nginx停止搜索其他匹配。
普通字符匹配,正则表达式规则和长的块规则将被优先和查询匹配,也就是说如果该项匹配还需去看有没有正则表达式匹配和更长的匹配。
^~ 则只匹配该规则,nginx停止搜索其他匹配,否则nginx会继续处理其他location指令。
最后匹配理带有"~"和"~*"的指令,如果找到相应的匹配,则nginx停止搜索其他匹配;当没有正则表达式或者没有正则表达式被匹配的情况下,那么匹配程度最高的逐字匹配指令会被使用。
location = / { # 只匹配"/". [ configuration A ] } location / { # 匹配任何请求,因为所有请求都是以"/"开始 # 但是更长字符匹配或者正则表达式匹配会优先匹配 [ configuration B ] } location ^~ /images/ { # 匹配任何以 /images/ 开始的请求,并停止匹配 其它location [ configuration C ] } location ~* \.(gif|jpg|jpeg)$ { # 匹配以 gif, jpg, or jpeg结尾的请求. # 但是所有 /images/ 目录的请求将由 [Configuration C]处理. [ configuration D ] }
另附一个根据cookie分发 的案例:
http://blog.csdn.net/rabbit2003/article/details/6580217
相关文章推荐
- nginx根据$remote_addr分发 nginx根据客户端IP分发
- nginx前端根据$remote_addr分发方法 推荐
- nginx根据客户端ip地理位置转发到不同服务器上(Geoip+nginx)
- nginx根据客户端ip动态代理后端服务-TCP
- nginx根据客户端ip进行简单转发(回发)
- nginx前端代理tomcat取真实客户端IP
- nginx反向代理到tomcat,并在request中获取客户端请求ip
- python分析nginx日志根据共性url屏蔽ip
- nginx获取客户端IP实现
- nginx与tomcat组合使用时获取客户端真实IP
- nginx反向代理后应用程序如何获取客户端真实IP?
- nginx反向代理后应用程序如何获取客户端真实IP?
- 020_nginx禁止ip默认参数是$remote_addr无法禁止真实ip的问题
- Nginx反向代理导致PHP获取不到正确的HTTP_HOST,SERVER_NAME,客户端IP的解决方法
- nginx反向代理到tomcat,并在request中获取客户端请求ip
- nginx做反向负载均衡,后端服务器获取真实客户端ip
- Nginx获取客户端IP实现(亲测可用)
- 根据Request获取客户端IP
- Nginx将不同IP的请求分发到不同的WEB服务器
- nginx做反向负载均衡,后端服务器获取真实客户端ip