nginx转发的问题


我在项目配置的时候遇到一个问题:

配置了域名转发,且配置了https

nginx配置如下:

bash 复制代码
server {
    listen 443 ssl;
    server_name yourdomain.com;

    ssl_certificate /path/to/your/certificate.crt;
    ssl_certificate_key /path/to/your/private.key;

    location / {
        proxy_pass http://backend_ip_address;
    }
}

浏览器访问的时候通过https://yourdomain.com/admin (静态文件的转发配置没有贴)

静态文件是可以读到的,但是在访问登录接口的时候出现问题了,看了下请求信息发现:

1、通过域名访问后,登录接口的请求的地址显示为后端登录接口服务器的IP地址

2、接口请求变成了http请求。

以上两个原因造成我的服务异常。

最终解决的方法:

再转发的时候没有保留原始的主机名传递给后端服务器

bash 复制代码
server {
    listen 443 ssl;
    server_name yourdomain.com;

    ssl_certificate /path/to/your/certificate.crt;
    ssl_certificate_key /path/to/your/private.key;
    
    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_ciphers HIGH:!aNULL:!MD5;

    location / {
        proxy_pass http://backend_ip_address;
        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_set_header X-Forwarded-Proto $scheme;
    }
}

总结下排查步骤:

1、检查 Nginx 配置:确保 server_name 配置正确,并且 proxy_set_header Host $host; 配置已包含。

2、检查后端服务:确认后端服务在返回重定向或生成 URL 时使用了正确的域名。

3、查看浏览器开发者工具:使用浏览器的开发者工具查看网络请求,检查重定向是否来自后端服务或 Nginx,并查看响应头中的 Location 字段

但是有个问题,同样的架构,我有一个其他的项目,location配置的时候只配置了proxy_pass,没有出现问题,先记录一下吧。

相关推荐
SakitamaX2 小时前
Nginx安装与实验
服务器·前端·nginx
小鸡食米6 小时前
Nginx基础
运维·服务器·nginx
市安1 天前
Swarm集群管理
运维·nginx·集群·镜像·swarm
水冗水孚2 天前
使用Nginx auth_basic实现轻量级用户名密码登录认证(小项目快速落地)
nginx
catoop2 天前
Nginx 解决 upstream sent too big header 错误
运维·nginx
市安2 天前
基于 Alpine 构建轻量 Nginx 错误页面 Docker 镜像
运维·nginx·docker·alpine
猫头虎3 天前
web开发常见问题解决方案大全:502/503 Bad Gateway/Connection reset/504 timed out/400 Bad Request/401 Unauthorized
运维·前端·nginx·http·https·gateway·openresty
Trouvaille ~5 天前
【Linux】网络进阶:NAT技术与代理服务器详解
linux·运维·网络·nginx·ip·nat·代理服务器
之歆5 天前
Nginx + Tomcat 反向代理完全指南
nginx·tomcat·firefox
匀泪5 天前
云原生(nginx实验(4))
运维·nginx·云原生