什么是反向代理?

反向代理 (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,用户完全感知不到后端服务器的存在。

相关推荐
cipher2 小时前
ERC-4626 通胀攻击:DeFi 金库的"捐款陷阱"
前端·后端·安全
毅航2 小时前
自然语言处理发展史:从规则、统计到深度学习
人工智能·后端
JxWang052 小时前
Task04:字符串
后端
树獭叔叔3 小时前
10-让模型更小更聪明,学而不忘:知识蒸馏与持续学习
后端·aigc·openai
JxWang053 小时前
Task02:链表
后端
只会cv的前端攻城狮4 小时前
Elpis-Core — 融合 Koa 洋葱圈模型实现服务端引擎
前端·后端
codetown4 小时前
2026年Zig编程语言权威指南:从系统级底层架构到现代软件工程实践
后端·程序员
cg336 小时前
cc-connect,十分钟帮你把 claude code 连接到微信,飞书,钉钉等等平台
后端·openai
用户1427868669326 小时前
Java多态的底层真相:JVM到底怎么知道该调哪个方法?(面试高频)
后端