什么是反向代理?

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

相关推荐
Sam_Deep_Thinking10 小时前
Spring Boot 的启动原理是什么?
java·spring boot·后端
南部余额10 小时前
Spring WebClient 从入门到精通
java·后端·spring
摇滚侠10 小时前
Spring 零基础入门到进阶 基于注解管理 Bean 38-43
xml·java·后端·spring·intellij-idea
SamDeepThinking11 小时前
我们当年是如何真实落地BFF的?
java·后端·架构
IVEN_11 小时前
记一次诡异的前端白屏故障:Nginx Proxy Cache 内存缓存"幽灵"事件
前端·nginx
Asmewill11 小时前
Centos系统docker时间同步方案
后端
用户83562907805111 小时前
使用 Python 操作 Word 评论和回复
后端·python
心在飞扬11 小时前
CentOS + Node.js 全套部署命令
后端
mqcode11 小时前
若依框架如何配置多数据源?同时连接 MySQL、SQL Server、Firebird 三种数据库
后端
协享科技12 小时前
Spring Boot 与 Go 双服务架构实践:从单体拆分到通信设计
java·人工智能·spring boot·后端·架构·golang·ai编程