Nginx:proxy_pass、root、rewrite、alias 的使用详解

1. 前言

nginx反向代理配置,常用的有好几种方式。比如:proxy_pass、root、alias、rewrite。通过这篇文章,你将了解他们的用法。

2. proxy_pass

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;
    }
}

3. root

  • root 的作用是将 location 的内容拼接到 root 后面
  • root 配置的是本地文件夹路径,而不是http路径

如下配置,浏览器打开 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/;
    }
}

4. alias

  • alias 作用是将请求地址剔除 location 配置的部分,然后拼接到 root 后面

如下配置,当请求地址是 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/;
    }
}

5. rewrite

  • rewrite 作用是地址重定向,语法:rewrite regex replacement[flag];
  • 根据 regex(正则表达式)匹配请求地址,然后跳转到 replacement,结尾是flag标记

如下例子,请求地址是 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调用

  • 2
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Nginx中,rootproxy_passalias是用于配置反向代理和处理请求路径的关键指令。 首先,root指令用于设置请求的根目录。当一个请求到达Nginx时,Nginx会根据请求的URL路径去寻找对应的文件或目录。通过root指令,可以指定请求的根目录,Nginx会以该目录作为基准去查找请求的资源。 中的例子展示了root的用法。在这个例子中,当请求的路径是/html2时,Nginx会在/usr/local/nginx/目录下寻找对应的资源。 接下来是proxy_pass指令,它用于设置反向代理的目标地址。当一个请求到达Nginx时,Nginx会将该请求转发到proxy_pass指定的目标服务器上,并将响应返回给客户端。这可以用于实现负载均衡或者将请求转发给其他服务器处理。 中的例子展示了proxy_pass的用法。在这个例子中,当请求路径是/html2时,Nginx会将请求转发到http://localhost:8080上进行处理。 最后是alias指令,它用于配置请求路径的别名。当一个请求到达Nginx时,alias指令会将请求路径中匹配到的部分剔除,并将剩余部分拼接到alias指令后面的路径中去寻找资源。 中的例子展示了alias的用法。在这个例子中,当请求路径是/api1时,Nginx会将路径中的/api1剔除,并在root后面拼接剩余部分,然后在/usr/local/nginx/目录下寻找对应的资源。 综上所述,root指令用于设置请求的根目录,proxy_pass指令用于设置反向代理的目标地址,alias指令用于配置请求路径的别名。这些指令可以根据实际需求来配置Nginx,实现灵活的请求处理和代理转发。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

°Fuhb

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值