nginx使用非80端口时url带端口号的解决办法

在nginx中配置server侦听非80端口时,我们在访问时会在url中加入对应的端口号,如:http://xxx.xxx.xxx:8006/,但如果在nginx服务器前有另一台服务器作为用户首先访问的web服务器,这台服务器设置了端口转发,将80端口获得的请求转发到nginx中的对应端口中,如8006,这时用户使用的url是没有端口号,但nginx会自动增加端口号到url上,很可能导致用户访问失败,可以将location 中增加proxy_set_header Host $host,即可解决此问题(在实际工作遇到,特此记下)

点赞 1
————————————————
版权声明:本文为CSDN博主「可能青蛙」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/hejun1218/article/details/73385437

 

 

在做Nginx反向代理时遇到个很烦人的问题,总是要显示端口号,查找了下终于找到解决办法

server {
listen 80;
server_name localhost;
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://127.0.0.1:8080/;
}
}

 


proxy_set_header Host $host:$server_port;  这段比较关键之前我没加$server_port就老是到下级请求出现真实端口号。

点赞 1
————————————————
版权声明:本文为CSDN博主「愤怒的苹果ext」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/baidu_19473529/article/details/53932300

 

nginx 反向代理 解决非80端口映射

写法一:
http {
    include       mime.types;
    default_type  application/octet-stream;

    sendfile        on;

    keepalive_timeout  65;

    #此处可以解决负载均衡问题
    upstream portalTest {
	server www.ceshitest.com:8089 weight=5;
	#server 192.168.0.102:8001 weight=2;
   }

    server {
        listen       80;
        server_name  www.ceshitest.com;
	proxy_redirect   off;
	# nginx非80端口处理 
        proxy_set_header Host $host:$server_port; 
        # 获取真实IP 
        #proxy_set_header X-Real-IP $remote_addr; 
        # 获取代理者的真实ip 
        #proxy_set_header X-Forwarded-For   $proxy_add_x_forwarded_for; 

        location / {

            proxy_pass   http://portalTest;
	    
        }

    }

}
<pre name="code" class="html">写法二:
http {
    include       mime.types;
    default_type  application/octet-stream;

    sendfile        on;

    keepalive_timeout  65;


    server {
        listen       80;
        server_name  www.ceshitest.com;
	

        location / {

            proxy_pass   http://<span style="font-family: Arial, Helvetica, sans-serif;">www.ceshitest.com:8089</span><span style="font-family: Arial, Helvetica, sans-serif;">;</span>
	    
        }

    }

}
————————————————
版权声明:本文为CSDN博主「笑面依旧」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/OXiaoMianYiJiu/article/details/51263476

  

nginx做非80端口转发

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

 

server {
listen 80;
server_name localhost;

location / {
    proxy_pass http://147.16.24.175: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。

正确的配置方法为

在 $host之后加上端口号,如$host:81

server {
        listen       83;
        server_name  localhost;

        location / {
         proxy_pass  http://147.16.24.175:9500 ;
         proxy_set_header   Host             $host:83;
         proxy_set_header   X-Real-IP        $remote_addr;
         proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
         proxy_set_header Via    "nginx";

        }
 }

==============
————————————————
版权声明:本文为CSDN博主「风月无边」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/xzknet/article/details/6342018

  

nginx监听非80端口时转发端口不正确问题

今天部署项目的时候碰到这样一个问题,对方服务器80端口不对外开放仅开放一个6659端口映射内网8080端口,因为不只一个地方需要8080端口因此需要nginx做代理,一开始nginx.conf配置是这样的:

 

 

 

这样配置项目部署之后碰到一个问题,静态资源无法访问,F12之后发现所有资源都请求到了8080端口(Tomcat里端口是8081),于是继续修改nginx配置如下:

 

 

 

重启nginx,项目运行成功。
————————————————
版权声明:本文为CSDN博主「zch1990s」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/zch1990s/article/details/79035659

posted @ 2020-03-04 17:53  mofy  阅读(27036)  评论(0编辑  收藏  举报