Nginx服务器中配置非80端口的端口转发方法详解

Quinta ·
更新时间:2024-11-13
· 860 次阅读

nginx可以很方便的配置成反向代理服务器:

  server {   listen 80;   server_name localhost;   location / {   proxy_pass http://x.x.x.x:9500;   proxy_set_header Host $host:80;   proxy_set_header X-Real-IP $remote_addr;   proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;   proxy_set_header Via "nginx";   }   }

但是如果nginx的监听端口不是默认的80端口,改为其他端口如81端口。
后端服务器中request.getServerPort()无法获得正确的端口,返回的仍然是80;
在response.sendRedirect()时,客户端可能无法获得正确的重定向url。
正确的配置方法下面我们详细来看:

增加Nginx虚拟主机

20164794024172.jpg (323×403)

要做Nginx的转发,当然就要对Nginx做配置。可以通过添加虚拟主机配置来增强Nginx的功能。首先看看Nginx的配置文件,笔者的Nginx文件是在/etc/nginx/nginx.conf。从上图可以看到Nginx在最后引入了vhosts.d目录下的配置文件。那么就要在/etc/nginx/vhosts.d目录下创建以.conf为后缀的文件(如果该目录不存在需要自己创建)。

Nginx做非80端口转发
要做转发,可以使用Nginx的proxy_pass配置项。Nginx监听80端口,接收到请求之后就会转发到要转发的URL。具体的配置如下:

server { server_name www.test.com listen 80; location / { proxy_pass http://127.0.0.1:8080; } }

是的,就是这么简单就可以了。这是配置端口转发的核心。

但是,当遇到需要获取真实IP的业务时,还需要添加关于真实IP的配置:

server { server_name www.test.com listen 80; location / { proxy_pass http://127.0.0.1:8080; proxy_set_header Host $host:80; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } }

proxy_set_header这句配置是改变http的请求头。而Host是请求的主机名,X-Real-IP是请求的真实IP,X-Forwarded-For表示请求是由谁发起的。

小结
这次的配置可能对大部分人来说都很简单,但是笔者刚接触Nginx配置这一块,因此记录下来,分享给有需要的人。如有建议和批评,欢迎指出。通过这次的学习发现,Nginx的配置是很值得学习的。

您可能感兴趣的文章:windows下nginx的安装使用及解决80端口被占用nginx不能启动的问题详解nginx同一端口监听多个域名和同时监听http与httpsnginx修改默认运行80端口的方法详解Nginx与Apache共用80端口的配置方法利用Nginx反向代理功能解决WEB网站80端口被封的解决方法nginx下的代理服务器80端口被封的解决方案封80端口应对策略 Nginx反向代理For WIN2003超级傻瓜式配置开启Nginx时端口被占用提示:Address already in use



方法 80端口 端口转发 Nginx

需要 登录 后方可回复, 如果你还没有账号请 注册新账号