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-03-29fail2ban nginx
- 2024-03-18install nginx proxy manager
- 2024-01-2444从零开始用Rust编写nginx,命令行参数的设计与解析及说明
- 2024-01-22比Nginx更好用的Gateway!
- 2024-01-17nginx daemon off
- 2023-12-30Nginx Vhost Traffic Status 是什么意思-icode9专业技术文章分享
- 2023-12-26使用nginx搭建creates.io镜像(稀疏索引)
- 2023-11-18centos7编译安装Nginx教程。
- 2023-11-02nginx启动命令和停止命令
- 2023-10-25Centos7系统Nginx负载均衡如何安装和配置?