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,没有出现问题,先记录一下吧。

相关推荐
龙卷风卷云13 小时前
【BUG】Nginx使用upstream后端接口报 400
运维·nginx·bug
Java面试题总结13 小时前
Nginx 配置笔记
运维·笔记·nginx
cyber_两只龙宝14 小时前
【Nginx】Nginx配置负载均衡详解
linux·运维·nginx·云原生·负载均衡
夜影风15 小时前
Tengine、OpenResty与Nginx三大Web服务中间件对比分析
nginx·openresty·技术架构
海的透彻2 天前
nginx启动进程对文件的权限掌控
运维·chrome·nginx
my_styles2 天前
linux系统下安装 tengine / 宝兰德等国产信创中间件和闭坑
linux·运维·服务器·spring boot·nginx·中间件
NGINX开源社区2 天前
从 F5 NGINX Ingress Controller 迁移到 F5 NGINX Gateway Fabric
nginx
Arvin6272 天前
Nginx 添加账号密码访问验证
运维·服务器·nginx
阿凤213 天前
nginx部署如何配置ssl证书
运维·nginx·ssl
zhyoobo3 天前
Nginx Gzip压缩全解析:原理、配置与性能优化指南
运维·nginx·性能优化