本文详细介绍了Nginx中proxy_pass、root、alias和rewrite四种反向代理配置方法。proxy_pass用于将请求转发到其他HTTP地址;root配置本地文件夹路径,用于静态资源服务;alias则将请求路径映射到指定目录;rewrite则进行URL重写,实现地址重定向。这些配置在搭建和优化Web服务时非常关键。
nginx反向代理配置,常用的有好几种方式。比如:proxy_pass、root、alias、rewrite。通过这篇文章,你将了解他们的用法。
proxy_pass 作用是将匹配到的原始地址,反向代理到另外的HTTP地址。因此,proxy_pass 通常配置为目标URL地址。
配置方式有以下两种情况:
proxy_pass 后面只有IP+端口,其他什么都没有,也不能以“/”结尾。此时代理的路径,是将请求路径IP+端口后面的部分,追加到 proxy_pass 后面
如下配置,当我们请求 http://192.168.25.131:9003/first/a.html,实际nginx代理地址为http://192.168.25.131:8080/first/a.html
server {
listen 9003;
server_name 192.168.25.131;
location /first {
proxy_pass http://localhost:8080;
}
}
proxy_pass后面除了IP+端口,还有其他内容。此时的匹配逻辑,是将 location 未匹配到的内容,追加到 proxy_pass 后面
如下配置,当我们请求 http://192.168.25.131:9003/first2/a.html,实际nginx代理地址为http://192.168.25.131:8080/first/a.html
server {
listen 9003;
server_name 192.168.25.131;
location /first2 {
proxy_pass http://localhost:8080/first;
}
}
如下配置,浏览器打开 http://192.168.25.131:9003/html2/index.html
实际请求的是 /usr/local/nginx/html2/index.html
server {
listen 9003;
server_name 192.168.25.131;
location /html2 {
root /usr/local/nginx/;
}
}
如下配置,当请求地址是 http://192.168.25.131:9003/modules/order/index.html
实际访问路径是 /usr/local/nginx/html2/views/order/index.html
server {
listen 9003;
server_name 192.168.25.131;
location /modules/ {
alias /usr/local/nginx/html2/views/;
}
}
如下例子,请求地址是 http://192.168.25.131:9003/baidu/开头的,都会跳转到百度
location /baidu/ {
rewrite ^/(.*) http://www.baidu.com/ permanent;
}
常用正则表达式:
字符 | 描述 |
---|---|
\ | 将后面接着的字符标记为一个特殊字符或者一个原义字符或一个向后引用 |
^ | 匹配输入字符串的起始位置 |
$ | 匹配输入字符串的结束位置 |
* | 匹配前面的字符零次或者多次 |
+ | 匹配前面字符串一次或者多次 |
? | 匹配前面字符串的零次或者一次 |
. | 匹配除“\n”之外的所有单个字符 |
(pattern) | 匹配括号内的pattern |
rewrite 最后一项flag参数:
标记符号 | 描述 |
---|---|
last | 本条规则匹配完成后继续向下匹配新的location URI规则 |
break | 本条规则匹配完成后终止,不在匹配任何规则 |
redirect | 返回302临时重定向 |
permanent | 返回301永久重定向 |
例子2:将 http://192.168.25.131:9003/api/ 开头的地址,重定向到http://192.168.25.131:9003/****。也就是说,将中间的 /api 去掉
location /api/ {
rewrite /api/(.*) /$1 break;
proxy_pass http://192.168.25.131:9003;
}
( ) --用于匹配括号之间的内容,通过$1、$2调用