Nginx 反向代理后端口丢失

事件起因是因为公司内部GitLab对外映射端口访问问题,在内网中使用80/443端口正常访问,对外使用非80端口访问主页会自动跳转到80端口,手动加上端口访问正常,但是这样极其影响使用体验。

一、背景描述

内网使用容器搭建了一个 GitLab 平台,内部Nginx 端口是8081,使用 IP+Port 的形式访问正常,再从其他机器上部署 Nginx 反向搭理后,使用域名的方式也是访问正常的,但是把反向搭理的端口改成非80/443端口,通过域名加端口形式访问主页时会跳转到80端口,导致访问失败,如下所示:

http://git.example.com:1443 — > http://git.example.com

手动在跳转后的 URL 地址中加上端口又访问正常,由此猜测可能 Nginx 配置问题。

二、问题解决

1、问题原因

Nginx 端口丢失导致,Nginx 没有正确的把端口信息传送到后端,没能正确的配置Nginx

2、问题解决

server {
    
    
    listen 8888;
    server_name localhost;
    location / {
    
    
        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;
    }
}

proxy_set_header Host $host:$server_port; 这一行是关键,获取真实端口必须设置。

猜你喜欢

转载自blog.csdn.net/qq_25854057/article/details/124706772