nginx rewrite proxy_pass location 的理解

原创caoshuming_500 最后发布于2014-07-11 21:25:26 阅读数 29615 收藏
展开
1. rewrire
rewrite 模块简介
rewrite 是nginx的重写模块,是一个正则表达式与虚拟机的结合。因为loaction是遍历都执行一遍(没有匹配成功就 /);所以,

rewrite 到新的uri后进入另外一个location ,恰好这个location也有rewrite 再次重新的uri 又调回原来的location;这样就是

四循环了,最多执行10次,然后报500错误。

rewrite 模块指令
set
if
return
last #rewrite 完成,但会进入location,再次rewrite
break #rewrite localtion 都完成,不会再进入localtion rewrite;但也不是用break就万事大吉了;有时必须用last

重写规则语法: rewrite 正则 替换 标志位
(1). 任何重写规则第一部分肯定是 正则表达式

可以用()来捕获正则表达式,然后在rewrite后面就用 $[d+] 来用这个正则表达式;比如:

^/images/([a-z]{2})/([a-z0-9]{5})/(.*)\.(png|jpg|gif)$ ---->http://xxxx.com/images/aa/abc01/test.gif
#其中
$1=([a-z]{2}) #$1=aa
$2=([a-z0-9]{5}) #$2=abc01
$3=(.*) #$3=test
$4=(png|jpg|gif) #$4=gif

上面的4个地段都是query 串中匹配的字符串

(2). 重写规则的第二部分是URI(rewrite 重写后url)
query 请求串被改写,包括上面正则表达式获取的参数字段和nginx 相关的配置,

/data?file=$3.$4 # rewrite之后的query http://data?file=test.gif
rewrite 之后会返回给客户端301 或者302  [ 会不会返回200]
(3).  重写规则的第三部分是:尾部的标记  flag last return break

laster 标记之后会从新loaction ,继续rewrite 最多10次

rewrite ‘^/images/([a-z]{2})/([a-z0-9]{5})/(.*)\.(png|jpg|gif)$‘ /data?file=$3.$4 last;
#<pre name="code" class="html">http://xxxx.com/images/aa/abc01/test.gif -----rewrite---> http://data?file=test.gif
break标记是直接跳槽rewrite和localtion 进行query的处理if ($bwhog) {

if ($bwhog) {
limit_rate 300k;
break;
}
return标记停止rewrite 处理指令,进而控制主HTTP 模块处理请求,也就是HTTP请求也不处理了,直接给client 返回(结合error0page,)

location = /image404.html {
return 404 "image not found\n";
}

(4). 整个过程的实例

http {
server {
root /home/www;

location / {
# 重写规则信息
error_log logs/rewrite.log notice;
# 注意这里要用‘’单引号引起来,避免{}
rewrite ‘^/images/([a-z]{2})/([a-z0-9]{5})/(.*)\.(png|jpg|gif)$‘ /data?file=$3.$4;
# 注意不能在上面这条规则后面加上“last”参数,否则下面的set指令不会执行
set $image_file $3;
set $image_type $4;
}

location /data {

rewrite /data?(.*) /error/img=$1 break; #break 就是最后的rewrite 结果,不会再次遍历localtion啦
}
location = /error/ {
# 图片不存在返回特定的信息
return 404 "image not found\n"; #如果是return HTTP 直接返回403 302 等状态码
}
}

2.location
根据正则表达式进行匹配query串, / 是所有的匹配中最低优先级,其他的不能匹配在到这里面处理;

如果其他的能精确匹配 就不会向下走,直接处理;

locaton 里面可以有proxy_pass 的命令和rewrite的命令

3.proxy_pass
把query 转发给指定的query串,这个query串是固定的,不能用正则表达式,也不能用老query串的参数;

rewrite 就可以用正则表达式,也可以用老query的串,所以相比 rewrite 更加灵活、强大
————————————————
版权声明:本文为CSDN博主「caoshuming_500」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/caoshuming_500/article/details/37700357

原文地址:https://www.cnblogs.com/fengff/p/12557904.html

时间: 2024-11-08 23:34:18

nginx rewrite proxy_pass location 的理解的相关文章

Nginx Rewrite正则表达式案例

前两天简单整理了下Nginx的URL Rewrite基本指令,今天谈谈Nginx Rewrite的location正则表达式. 1.Nginx Rewrite 基本标记(flags) last 相当于Apache里的[L]标记,表示完成rewrite break 本条规则匹配完成之后,终止匹配,不再匹配后面的规则. redirect 返回302临时重定向 地址栏会显示跳转后的地址 permanent 返回301永久重定向 地址栏会显示跳转后的地址 2.正则表达式: 1)变量名,错误的值包括:空字

[转帖]Nginx rewrite 规则 与 proxy_pass 实现

https://www.cnblogs.com/jicki/p/5546916.html Nginx rewrite 规则  与 proxy_pass 实现 ------------------------------------------------------------------------------------------------------ ~         大小写敏感匹配 ~*        大小写不敏感匹配 !~        大小写敏感不匹配 !~*       大小

Nginx Rewrite规则

location = / { # 精确匹配 / ,主机名后面不能带任何字符串 [ configuration A ] } location / { # 因为所有的地址都以 / 开头,所以这条规则将匹配到所有请求 # 但是正则和最长字符串会优先匹配 [ configuration B ] } location /documents/ { # 匹配任何以 /documents/ 开头的地址,匹配符合以后,还要继续往下搜索 # 只有后面的正则表达式没有匹配到时,这一条才会采用这一条 [ configu

nginx rewrite标签配置以及用户认证配置

一.nginx  rewrite标签 rewrite 实现URL的改写主要是实现伪静态 1.  rewrite指令语法 指令语法:rewrite regex replacement[flag] 默认值:none 应用位置:server,location,if rewrite是实现URL重写的关键指令,根据regex(正则表达式)部分内容,重定向到replacement部分内容,结尾是flag标记,下面是一个简单的URL Rewrite跳转 Rewrite ^/(.*)http://www.eti

nginx——rewrite模块

1.什么是Nginx的Rewrite规则? Rewrite主要的功能就是实现URL的重写,Nginx的Rewrite规则采用PCRE(Perl Compatible Regular Expressions)Perl兼容正则表达式的语法进行规则匹配,如果 您需要Nginx的Rewrite功能,在编译Nginx之前,须要编译安装PCRE库. 通过Rewrite规则,可以实现规范的URL,根据变量来做URL转向及选择配置. (1)一些使用MVC框架的程序只有一个入口,可以通过Rewrite来实现. (

nginx rewrite php的CI(CodeIgniter)框架

一. 了解nginx rewrite: 正则表达式匹配,其中: * ~ 为区分大小写匹配    * ~* 为不区分大小写匹配    * !~和!~*分别为区分大小写不匹配及不区分大小写不匹配 文件及目录匹配,其中: * -f和!-f用来判断是否存在文件    * -d和!-d用来判断是否存在目录    * -e和!-e用来判断是否存在文件或目录    * -x和!-x用来判断文件是否可执行 flag标记有: * last 相当于Apache里的[L]标记,表示完成rewrite    * bre

nginx rewrite模块探究与实验

关于nginx中的rewrite,之前的理解总感觉有些不精确.比如以下问题,经过rewrite之后: 什么情况会返回200? 什么情况会返回301/302? 什么情况浏览器里的url不变? 什么情况浏览器里的url会变? 什么情况匹配一次就不再匹配之后的规则或location? 什么情况匹配到一条规则后,会以rewrite之后的url再到server段走一遍 如果读者能理解清楚以上问题,则说明对nginx的rewrite整体上已经有了全面的认识. 接下来我们针对以上问题,来通过试验逐一解答 实验

Nginx之 proxy_pass实现代理 小记

Nginx之 proxy_pass 小记 1.环境介绍: Nginx :开启80端口访问 Apache :开启两个虚拟主机分别是 端口88 .端口 89 2.配置文件: Apahce虚拟主机 <VirtualHost *:89> DocumentRoot /usr/share/ganglia <Directory "/usr/share/ganglia"> AllowOverride None          Require all granted Order

Nginx Rewrite规则记录

Rewrite 是一种服务器的重写脉冲技术,它可以使得服务器可以支持 URL 重写,是一种最新流行的服务器技术.它还可以实现限制特定IP访问网站的功能.很多情况下,某个 IP 的访问很容易造成 CPU 100% (比如 某些搜索引擎的固定抓取,别人大量的采集站点),这个时候我们就要利用一些有效的手段封掉对方的 IP,让他无法消耗服务器的资源,封 IP 的方法有很多种,如果你的 Web(Nginx|Apache|other) 服务器安装了 Rewrite 模块的话,也可以试试利用 Rewrite