当前位置: 首页 > article >正文

nginx中proxy_pass和root的区别

location 配置中,proxy_passroot完全不同的指令,它们的作用和适用场景不同。


1. proxy_pass:代理请求到后端服务器

location /api/ {
    proxy_pass http://http_backend;
}

作用

  • 把请求转发到后端服务器 http_backend,即 Nginx 作为反向代理
  • 适用于Nginx 作为 API 网关或负载均衡的情况。

示例

如果 http_backendhttp://127.0.0.1:8080

  • 访问 http://example.com/api/user,请求会被转发到 http://127.0.0.1:8080/api/user
  • Nginx 不处理文件,直接把请求转发给后端服务器

2. root:从本地目录读取静态文件

location /static/ {
    root /usr/share/nginx/webroot;
}

作用

  • Nginx 直接从服务器本地读取静态资源(HTML、CSS、JS、图片等)。
  • 适用于网站静态资源托管

示例

如果 root /usr/share/nginx/webroot;

  • 访问 http://example.com/static/logo.png
  • Nginx 直接返回 /usr/share/nginx/webroot/static/logo.png 文件,不会走代理。

3. proxy_pass vs root 的主要区别

对比项proxy_passroot
作用把请求转发到后端服务器直接读取本地文件
适用场景代理 API、微服务、后端服务器提供静态资源(HTML、CSS、JS)
请求路径解析代理时请求路径可能变化直接映射本地路径
Nginx 处理方式转发请求,不读取文件直接读取并返回文件
示例proxy_pass http://backend;root /var/www/html;

4. 什么时候用 proxy_pass,什么时候用 root

使用 proxy_pass 的场景

  • 反向代理 API,如 http://backend/api
  • Nginx 作为网关,将请求转发给 Spring Boot、Node.js、Django 等后端服务。

使用 root 的场景

  • 提供前端 index.html、CSS、JS、图片等静态资源。
  • 部署 Vue、React、Angular 前端应用时,Nginx 直接托管 dist/ 目录。

5. 示例:静态资源 + API 代理

server {
    listen 80;

    # 代理 API 请求
    location /api/ {
        proxy_pass http://backend_server;
    }

    # 提供静态资源
    location / {
        root /usr/share/nginx/webroot;
        index index.html;
    }
}
  • 访问 /api/users -> 转发给 backend_server(后端处理)。
  • 访问 /index.html -> 直接从 webroot 目录读取 index.html

总结

  • proxy_pass:用于 反向代理,Nginx 不处理文件,直接转发请求给后端服务器。
  • root:用于 静态资源托管,Nginx 直接读取本地文件并返回
  • 可以混合使用proxy_pass 处理 API,root 处理静态资源。

🚀 合理使用 proxy_passroot,可以让 Nginx 既能做代理,又能提供静态资源! 🚀


http://www.kler.cn/a/584658.html

相关文章:

  • STL-List模拟
  • 【QT】:QT图形化界面相关准备工作
  • 【python运行Janus-Pro-1B文生图功能】
  • 开源!速度100Kb/s的有线和无线双模ESP32S3芯片的DAP-Link调试器
  • 深入理解 RTP、RTCP、RTMP、RTSP、HLS 及 live555 推拉流实现
  • 【经验分享】SpringBoot集成Websocket开发 之 使用由 Jakarta EE 规范提供的 API开发
  • docker基本应用和相关指令
  • MySQL小练习
  • 大数据面试之路 (三) mysql
  • 在Vue中如何高效管理组件状态?
  • 蓝桥每日打卡--数组美丽值求和
  • LM Studio 替换源的方式解决huggingface.co无法访问的问题
  • Java 无 GUI 浏览器:HtmlUnit 入门及实战 [特殊字符]
  • 地理信息系统(ArcGIS)在水文水资源、水环境中的应用
  • ClickHouse 通过 ​*ARRAY JOIN* 结合 ​Map 类型的内置函数取数值
  • ollama docker离线安装本地大模型
  • 如何解决Redis的缓存雪崩、缓存击穿、缓存穿透?
  • Flink状态管理深度探索:从Keyed State到分布式快照
  • 在 Windows 系统下使用 VMware 安装 Ubuntu 24.04 LTS 系统
  • unittest vs pytest区别