什么是反向代理?

反向代理 (Reverse Proxy)是一种位于目标服务器集群前端的代理服务器,它接收客户端发起的请求,然后根据规则将请求转发给后端的目标服务器,再将目标服务器的响应结果返回给客户端。

简单来说,正向代理 是"替客户端办事"(比如翻墙工具),客户端知道目标服务器的地址;而反向代理是"替服务器办事",客户端不知道后端真实服务器的地址,只知道反向代理服务器的地址。


核心特点

  1. 隐藏后端服务器

    客户端只能看到反向代理的地址,无法直接访问后端的真实服务器,从而保护后端服务器的安全,避免直接暴露在公网中。

  2. 请求转发与负载均衡

    当后端有多台服务器时,反向代理可以按照预设策略(如轮询、加权轮询、最少连接数)将请求分发到不同服务器,实现负载均衡,提升系统整体吞吐量和稳定性。

  3. 功能扩展

    • 缓存加速:缓存后端服务器的静态资源(如图片、CSS、JS),后续相同请求直接返回缓存内容,减轻后端压力。
    • SSL 终端:统一处理 HTTPS 加密解密,后端服务器只需处理 HTTP 请求,简化证书管理。
    • 过滤与防护:拦截恶意请求(如 SQL 注入、XSS),充当应用防火墙(WAF)的角色。
    • URL 重写:修改客户端请求的 URL 路径,适配后端服务器的路由规则。

典型应用场景

  1. 网站集群部署

    大型网站(如电商、新闻平台)的后端通常有多台 Web 服务器,反向代理(如 Nginx、Apache Traffic Server)负责分发用户请求,避免单台服务器过载。

  2. 微服务架构

    在微服务系统中,反向代理(或 API 网关,如 Kong、Spring Cloud Gateway)作为入口,接收客户端请求并路由到对应的微服务实例,同时统一处理认证、限流、监控等功能。

  3. CDN 服务

    CDN 的核心就是反向代理网络,边缘节点缓存源站内容,用户请求优先命中边缘节点,实现就近访问,降低延迟。


正向代理 vs 反向代理 核心区别

特性 正向代理 反向代理
代理对象 客户端 后端服务器集群
客户端感知 知道正向代理的存在 不知道后端服务器的存在
主要目的 突破访问限制、隐藏客户端 IP 负载均衡、保护后端、缓存加速
典型工具 代理服务器、VPN Nginx、HAProxy、Apache

举例:Nginx 反向代理配置(简化版)

nginx 复制代码
server {
    listen 80;
    server_name example.com;

    # 反向代理规则:将请求转发到后端服务器集群
    location / {
        proxy_pass http://backend_servers;  # 后端服务器组
        proxy_set_header Host $host;        # 传递请求头
        proxy_set_header X-Real-IP $remote_addr;  # 传递客户端真实IP
    }
}

# 后端服务器组(负载均衡)
upstream backend_servers {
    server 192.168.1.100:8080 weight=2;  # 权重2,优先分配请求
    server 192.168.1.101:8080 weight=1;
}

在这个配置中,用户访问 example.com 时,请求会被 Nginx 接收,然后转发到 192.168.1.100192.168.1.101,用户完全感知不到后端服务器的存在。

相关推荐
Charlo1 天前
手把手配置 Ralph -- 火爆 X 的全自动 AI 编程工具
前端·后端·github
CRUD酱1 天前
后端使用POI解析.xlsx文件(附源码)
java·后端
2501_941802481 天前
从缓存更新到数据一致性的互联网工程语法实践与多语言探索
java·后端·spring
钱多多_qdd1 天前
springboot注解(五)
java·spring boot·后端
小白冲鸭1 天前
苍穹外卖-前端环境搭建-nginx双击后网页打不开
运维·前端·nginx
IT_陈寒1 天前
React 18实战:这5个新特性让我的开发效率提升了40%
前端·人工智能·后端
a努力。1 天前
京东Java面试被问:双亲委派模型被破坏的场景和原理
java·开发语言·后端·python·面试·linq
不如打代码KK1 天前
Springboot如何解决跨域问题?
java·spring boot·后端
oMcLin1 天前
如何在 Debian 11 上配置并优化 Nginx 与 Lua 脚本,提升高并发网站的动态请求处理能力?
nginx·debian·lua