Nginx 使用非 80 端口反向代理跳转到 80 端口的问题

在一个项目中,我们简单的对内部服务器的 8080 端口做了一个反向代理,代理到另一台公网服务器的 8080 端口上。

Nginx 使用非 80 端口反向代理跳转到 80 端口的问题

在一个项目中,我们简单的对内部服务器的 8080 端口做了一个反向代理,来代理到另一台公网服务器的 8080 端口上。

upstream opac_server {
    server 54.xx.xxx.181:8080;
}
server {
    listen 8080;
    server_name 192.168.xx.xxx;
    
    access_log /var/log/nginx/opac_access.log main;
    error_log /var/log/nginx/opac_error.log warn;

    location / {
        proxy_redirect off;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass http://opac_server/;
    }

    error_page 404 /404.html;
        location = /40x.html {
    }

    error_page 500 502 503 504 /50x.html;
        location = /50x.html {
    }
}

当访问 http://192.168.xx.xxx:8080 时,页面无响应,但直接访问 http://54.xx.xxx.181:8080 正常。
如果带上路径访问,又是正常的,如: http://192.168.xx.xxx:8080/opac/recn

这是怎么回事呢?

原来,如果nginx的监听端口不是默认的80端口,改为其他非80端口后,后端服务tomcat中的request.getServerPort()方法无法获得正确的端口号,仍然返回到80端口。在response.sendRedirect()时,客户端可能无法获得正确的重定向URL。

正确的配置是,在proxy_set_header设置header的真实返回端口。

        proxy_set_header Host $host:8080;