nginx如何通过proxy_pass设置反向代理,隐藏端口号
通过proxy_pass设置反向代理,隐藏端口号
nginx配置修改,通过 proxy_pass 设置反向代理,监听域名(IP)转发到指定端口。
server { listen 80; server_name www.xxx.com; server_name_in_redirect off; proxy_set_header Host $host:$server_port; proxy_set_header X-Real-IP $remote_addr; proxy_set_header REMOTE-HOST $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; location / { proxy_pass http://www.xxx.com:8978; } }
nginx proxy_pass的配置
Nginx的官网将proxy_pass分为两种类型:
- 不带URI方式:只包含IP和端口号的,不带uri(单个/也算uri),比如
proxy_pass http://localhost:8080
; - 带URI方式:在端口号之后有其他路径的,包含了只有单个
/
的如proxy_pass http://localhost:8080/
,以及其他路径,比如proxy_pass http://localhost:8080/abc
。
URL末尾存在 uri
处理逻辑:
代理请求时,会先将请求的uri中和location匹配的部分替换成 proxy_pass 指定的uri,再将最终的uri拼接到代理地址,才是最终访问的url
如:
location /proxy { proxy_pass http://127.0.0.1:8099/svr1; # uri为'/svr1' }
发送如下请求:http://localhost:8088/proxy/index.html
详细解析:
- 请求的uri:/proxy/index.html
- location匹配的部分:/proxy
- proxy_pass 指定的uri:/svr1
- 最终的uri:/svr1/index.html (将请求的uri中和location匹配的部分替换成 proxy_pass 指定的uri)
- 代理地址:http://127.0.0.1:8099
- 最终访问的url:http://127.0.0.1:8099/svr1/index.html
- 即访问 http://localhost:8088/proxy/index.html,
- 实际请求路径为 http://127.0.0.1:8099/svr1/index.html
URL末尾不存在 uri
处理逻辑:
代理请求时,直接将请求的uri拼接到代理地址,就是最终访问的url
如:
location /proxy2 { proxy_pass http://127.0.0.1:8099; # 无uri }
发送如下请求:http://localhost:8088/proxy2/index.html
详细解析:
- 请求的uri:/proxy2/index.html
- 代理地址:http://127.0.0.1:8099
- 最终访问的url:http://127.0.0.1:8099/proxy2/index.html
- 即访问 http://localhost:8088/proxy2/index.html,
- 实际请求路径为 http://127.0.0.1:8099/proxy2/index.html
下面的几个例子加深理解
server { listen 80; server_name localhost; location /api1/ { proxy_pass http://localhost:8080; } # http://localhost/api1/xxx -> http://localhost:8080/api1/xxx location /api2/ { proxy_pass http://localhost:8080/; } # http://localhost/api2/xxx -> http://localhost:8080/xxx location /api3 { proxy_pass http://localhost:8080; } # http://localhost/api3/xxx -> http://localhost:8080/api3/xxx location /api4 { proxy_pass http://localhost:8080/; } # http://localhost/api4/xxx -> http://localhost:8080//xxx,请注意这里的双斜线,好好分析一下。 location /api5/ { proxy_pass http://localhost:8080/haha; } # http://localhost/api5/xxx -> http://localhost:8080/hahaxxx,请注意这里的haha和xxx之间没有斜杠,分析一下原因。 location /api6/ { proxy_pass http://localhost:8080/haha/; } # http://localhost/api6/xxx -> http://localhost:8080/haha/xxx location /api7 { proxy_pass http://localhost:8080/haha; } # http://localhost/api7/xxx -> http://localhost:8080/haha/xxx location /api8 { proxy_pass http://localhost:8080/haha/; } # http://localhost/api8/xxx -> http://localhost:8080/haha//xxx,请注意这里的双斜杠。 }
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
keepalived+lvs 对nginx做负载均衡和高可用的操作方法
这篇文章主要介绍了keepalived+lvs 对nginx做负载均衡和高可用的操作方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧2023-12-12在Nginx中使用X-Sendfile头提升PHP文件下载的性能(针对大文件下载)
这篇文章主要介绍了在Nginx中使用X-Sendfile头提升PHP文件下载的性能,可以用在针对大文件下载的情况,下载非网站Web目录文件的需求,提供下载权限控制的场景,需要的朋友可以参考下2014-07-07
最新评论