小知识:详解nginx rewrite和根据url参数location

最近项目中涉及到旧老项目迁移,需要在nginx上做些配置,所以简单学习了下,好记性不如烂笔头,先记下来。

rewrite

首先查看下nginx是否支持rewrite:

?
1
./nginx -V

不支持说明安装nginx时候缺少pcre,需要重新安装nginx:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#安装pcre
wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.34.tar.gz
tar -zxvf pcre-8.34.tar.gz
cd pcre-8.34
./configure
make
make install
#安装nginx
cd nginx-1.0.12
./configure –conf-path=/usr/local/nginx/conf/nginx.conf \
–pid-path=/usr/local/nginx/nginx.pid \
–with-http_ssl_module \
–with-pcre=/usr/local/src/pcre-8.34 \
make
make install
#启动nginx
./nginx
#重启nginx
./nginx –s reload

示例:

比如现有如下的nginx配置:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
worker_processes 24;
#worker_cpu_affinity 0000000000000001;
worker_rlimit_nofile 65535;
error_log logs/error.log crit;
pid    logs/nginx.pid;
events {
use  epoll;
worker_connections 2048000;
}
http {
include    mime.types;
default_type application/octet-stream;
charset utf-8;
sendfile    on;
tcp_nopush   on;
tcp_nodelay   on;
keepalive_timeout 60;
client_max_body_size    10m;
client_body_buffer_size   128k;
upstream log {
server 192.168.80.147:8338;
}
server {
listen    6061;
server_name 192.168.71.51;
location / {
proxy_pass         http://log;
proxy_redirect       off;
proxy_set_header      Host $host;
proxy_set_header      Remote_Addr $remote_addr;
proxy_set_header  X-REAL-IP $remote_addr;
proxy_set_header      X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_connect_timeout    90;
proxy_send_timeout     90;
proxy_read_timeout     90;
proxy_buffer_size      4k;
proxy_buffers        4 32k;
proxy_busy_buffers_size   64k;
proxy_temp_file_write_size 64k;
}
error_page  500 502 503 504 /50x.html;
location = /50x.html {
root  html;
}
log_format log $remote_addr – $remote_user [$time_local] “$request”
$status $body_bytes_sent “$http_referer”
“$http_user_agent” “$http_x_forwarded_for”;
access_log logs/access_log.log log;
#设定查看Nginx状态的地址 
location /NginxStatus {
#stub_status on; 
access_log on; 
auth_basic “NginxStatus”; 
#auth_basic_user_file conf/htpasswd; 
}
}
}

现在需要作如下的重定向:

192.168.71.51/log.aspx –> 192.168.80.147:8338/log

192.168.71.51/do.aspx –> 192.168.80.147:8338/do

192.168.71.51/uplog.aspx –> 192.168.80.147:8338/log

可以如下配置:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
server {
listen    6061;
server_name 192.168.71.51;
rewrite ^(.*)(?i)uplog.aspx(.*)$ $1log$2 break;
rewrite ^(.*)(?i)log.aspx(.*)$ $1log$2 break;
rewrite ^(.*)(?i)do.aspx(.*)$ $1do$2 break;
location / {
proxy_pass         http://log;
proxy_redirect       off;
proxy_set_header      Host $host;
proxy_set_header      Remote_Addr $remote_addr;
proxy_set_header  X-REAL-IP $remote_addr;
proxy_set_header      X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_connect_timeout    90;
proxy_send_timeout     90;
proxy_read_timeout     90;
proxy_buffer_size      4k;
proxy_buffers        4 32k;
proxy_busy_buffers_size   64k;
proxy_temp_file_write_size 64k;
}

关于这里的rewrite配置主要说明以下几点:

rewrite用法: rewrite 正则 替换 标志位 第一行配置和第二行配置顺序不能颠倒,因为nginx会从上往下依次rewrite(break在这里不起作用); (?!)表示忽略大小写匹配(网上说的是~*,但好像不起作用,我的nginx版本是1.0.12);  1,1,2表示前面正则表达式匹配到的部分;  rewrite可以在server里也可以在location里,nginx会首先执行server里的rewrite,然后才会执行location,意味着location的是重写后的url,之后还会执行location里的rewrite,最后nginx还会拿结果去执行剩下的location。

根据url参数location

实际开发中经常有根据请求参数来路由到不同请求处理者的情况,根据POST请求参数需要些nginx插件,这里主要简单介绍下如何根据GET参数来路由。

还是上面的配置文件。比如我们希望访问http://192.168.71.51:6061/do1.aspx?t=1212&c=uplog当url中的参数c为config或uplog的时候(忽略大小写)我们路由到其他地方:

首先增加一个upstream,比如:

?
1
2
3
4
5
6
……
upstream other {
server 192.168.71.41:2210;
}
……

然后在location里增加如下的判断即可:

?
1
2
3
4
5
6
7
……
location / {
if ( $query_string ~* ^(.*)c=config\b|uplog\b(.*)$ ){
proxy_pass         http://other;
}
……

关键是标红的行,$query_string表示url参数,后面是标准的正则匹配,需要的注意的是nginx中if有很多限制,语法很苛刻,具体参看上面的文档。

 很简单却很实用的配置,希望能帮到正在找这方面信息的同学。

声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。
建站知识

小知识:Linux新手入门系列:用户及组管理

2023-4-28 3:10:41

建站知识

小知识:基础:在 Linux 终端中移动文件

2023-4-28 3:18:56

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索