nginx URL重写(rewrite)和proxy_pass
2022/7/9 5:21:43
本文主要是介绍nginx URL重写(rewrite)和proxy_pass,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
公司的接口服务分对外和对内,对外的统一在URL前面加上 /xx-api/ , 由于对系统是怎么同时支持两套路由的不是很懂,所以去看了下nginx的配置,发现原来用rewrite就能做到
公司配置
server { listen 80; server_name localhost; location /xxx-api/ { rewrite ^/xxx-api/(.*)$ /$1 break; proxy_next_upstream off; proxy_set_header Host $host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Real-IP $remote_addr; proxy_set_header Remote-Addr $remote_addr; proxy_set_header Remote-Port $remote_port; proxy_pass_header Server; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "Upgrade"; proxy_pass http://xxx-yy-core:9102; } ... }
rewrite语法
rewrite regex replacement [flag]; # 关键字 正则 替代内容 flag标记
flag | 含义 |
---|---|
break | 本条规则匹配完成后立即终止,不再向后匹配任何规则 |
redirect | 302临时重定向,浏览器地址会显示跳转后的url地址 |
permanent | 301永久重定向,浏览器地址栏会显示跳转后的url地址 |
所以rewrite ^/xxx-api/(.*)$ /$1 break;
的含义就是 把URL的 xxx-api去掉.
proxy_pass 反向代理转发
proxy_pass http://xxx-yy-core:9102;
, 这里没有/,表示相对路径,把匹配的路径部分也给代理走。如 http://localhost:80/xxx-api/zzzType/add
, 会被转发成 http://xxx-yy-core:9102/zzzType/add
,中间的 zzzType
不会被去掉
这篇关于nginx URL重写(rewrite)和proxy_pass的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-12-13用Nginx防范DDoS攻击的那些事儿
- 2024-12-13用Terraform在AWS上搭建简单NGINX服务器指南
- 2024-10-29Nginx发布学习:从入门到实践的简单教程
- 2024-10-28Nginx发布:新手入门教程
- 2024-10-21nginx 怎么设置文件上传最大20M限制-icode9专业技术文章分享
- 2024-10-17关闭 nginx的命令是什么?-icode9专业技术文章分享
- 2024-09-17Nginx实用篇:实现负载均衡、限流与动静分离
- 2024-08-21宝塔nginx新增8022端口方法步骤-icode9专业技术文章分享
- 2024-08-21nginx配置,让ws升级为wss访问的方法步骤-icode9专业技术文章分享
- 2024-08-15nginx ws代理配置方法步骤-icode9专业技术文章分享