事件起因是因为公司内部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; 这一行是关键,获取真实端口必须设置。
|