用Nginx做端口转发(反向代理)
将域名转发到本地端口将域名转发到另一个域名本地一个端口转发到另一个端口或另一个域名加 / 与不加 /有时我们会使用一些java或node应用,但又不想让他们直接监听80端口,这时就需要用到端口转发
本文中,我们介绍Nginx如何做端口转发,还有各种转发规则
将域名转发到本地端口
首先介绍最常用的,将域名转发到本地另一个端口上
server{listen 80;server_name ;index index.php index.html index.htm;location / {proxy_pass http://127.0.0.1:8080; # 转发规则proxy_set_header Host $proxy_host; # 修改转发请求头,让8080端口的应用可以受到真实的请求proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}}
这样访问 时就会转发到本地的 8080 端口
将域名转发到另一个域名
server{listen 80;server_name ;index index.php index.html index.htm;location / {proxy_pass ;proxy_set_header Host $proxy_host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}}
这样访问 时就会转发到
本地一个端口转发到另一个端口或另一个域名
server{listen 80;server_name 127.0.0.1; # 公网ipindex index.php index.html index.htm;location / {proxy_pass http://127.0.0.1:8080; # 或 proxy_set_header Host $proxy_host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}}
这样访问 http://127.0.0.1 时就会转发到本地的 8080 端口或
加 / 与不加 /
在配置proxy_pass代理转发时,如果后面的url加/,表示绝对根路径;如果没有/,表示相对路径
例如
加 /
server_name location /data/ {proxy_pass http://127.0.0.1/;}
不加 /访问 /data/index.html 会转发到http://127.0.0.1/index.html
server_name location /data/ {proxy_pass http://127.0.0.1;}
访问 /data/index.html 会转发到http://127.0.0.1/data/index.html