【Python Web全栈开发】通过nginx实现http代理

示例

复制代码
server {
    listen   8888;    # 监听端口
    location / {
        proxy_set_header Host $http_host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass http://127.0.0.1:8088/; # 转发目标
    }

    location /prod-api {
        proxy_set_header Host $http_host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_pass http://127.0.0.1:9099/; # 转发目标
        rewrite ^/prod-api/(.*)$ /$1 break;   # url替换
    }

    error_page   500 502 503 504  /50x.html;  # 错误页面拦截,以免输出真实的错误页面
    location = /50x.html {
        root   html;
    }
}

内部量含义

  1. $http_host

    $http_host是客户端请求中的 Host 头字段的值。它通常包含客户端请求的域名或 IP 地址以及端口号(如果有)

  2. $remote_addr

    如果客户端(浏览器)直接访问 Nginx,remote_addr 就是客户端的真实 IP 地址。

    如果客户端通过代理服务器(如 CDN、负载均衡器、反向代理等)访问 Nginx,remote_addr 是代理服务器的 IP 地址,而不是客户端的真实 IP 地址。

  3. $proxy_add_x_forwarded_for

    proxy_add_x_forwarded_for 是一个用于构建 X-Forwarded-For 头字段的变量。X-Forwarded-For 是一个标准的 HTTP 头字段,用于记录请求经过的代理服务器的 IP 地址链。

    • 如果请求中没有 X-Forwarded-For 头,proxy_add_x_forwarded_for 的值就是 remote_addr(客户端的 IP 地址)。
    • 如果请求中已经有 X-Forwarded-For 头,proxy_add_x_forwarded_for 会在其值后面追加 , $remote_addr。

如果客户端 IP 是 192.168.1.100,且请求中没有 X-Forwarded-For 头,那么 $proxy_add_x_forwarded_for 的值就是 192.168.1.100。

如果客户端 IP 是 192.168.1.100,且请求中已经有 X-Forwarded-For 头值为 203.0.113.195,那么 $proxy_add_x_forwarded_for 的值就是 203.0.113.195, 192.168.1.100。

相关推荐
jinxinyuuuus4 小时前
vsGPU:硬件参数的数据仓库设计、ETL流程与前端OLAP分析
前端·数据仓库·etl
Evan芙4 小时前
Nginx 平滑升级
数据库·nginx·ubuntu
小信丶4 小时前
解决 pnpm dev 报错:系统禁止运行脚本的问题
前端·vue.js·windows·npm
૮・ﻌ・5 小时前
Vue3:组合式API、Vue3.3新特性、Pinia
前端·javascript·vue3
前端不太难5 小时前
RN + TypeScript 项目越写越乱?如何规范架构?
前端·javascript·typescript
神算大模型APi--天枢6465 小时前
全栈自主可控:国产算力平台重塑大模型后端开发与部署生态
大数据·前端·人工智能·架构·硬件架构
苏打水com5 小时前
第十五篇:Day43-45 前端性能优化进阶——从“可用”到“极致”(对标职场“高并发场景优化”需求)
前端·css·vue·html·js
@大迁世界5 小时前
08.CSS if() 函数
前端·css
Moment5 小时前
小米不仅造车,还造模型?309B参数全开源,深度思考完胜DeepSeek 🐒🐒🐒
前端·人工智能·后端
苏打水com5 小时前
第十六篇:Day46-48 前端安全进阶——从“漏洞防范”到“安全体系”(对标职场“攻防实战”需求)
前端·javascript·css·vue.js·html