正向代理和反向代理

简介: 本文详细介绍了代理和反向代理的概念及应用场景。代理作为一种中间人服务,可细分为正向代理与反向代理。前者位于客户端与网络间,有助于匿名浏览、访问控制、缓存加速及增强安全性;后者则位于网络与服务器间,主要用于负载均衡、缓存、安全性提升、SSL终止及内容过滤等。两者各有侧重,可根据具体需求选择使用。例如,Squid 是常用的正向代理框架,而 Nginx 则常用于反向代理。了解并合理运用两者,能有效提升网络性能与安全性。

Hi,你好,我是猿java。

在日常工作中,我们经常会听到代理和反向代理这两个词,那么,什么是代理?什么又是反向代理?为什么有了代理还需要反向代理?他们之间有什么差异?今天我们就来一起聊一聊。

定义

在计算机和网络领域,代理(proxy)通常是一种充当中间人的服务器或服务,用于转发客户端(通常是用户计算机)和目标服务器之间的请求和响应。它主要包括正向代理(forward proxy)和反向代理(reverse proxy)。

正向代理

在维基百科中,正向代理的定义是这样的:

正向代理:Forward Proxy,也称网络代理,就是我们通常说的代理,它是一种特殊的网络服务,允许一个终端(一般为客户端)通过这个服务与另一个终端(一般为服务器)进行非直接的连接。一些网关、路由器等网络设备具备网络代理功能。一般认为代理服务有利于保障网络终端的隐私或安全,在一定程度上能够阻止网络攻击。

正向代理的模型示意图如下:

proxy.png

从上图可以看出,正向代理位于客户端和网络之间,可以将客户端全部隐藏在代理后面。当客户端在发起网络请求时,不直接连接到目标服务器,而是将请求发送到正向代理服务器。正向代理服务器代表客户端向目标服务器请求数据,并将响应返回给客户端。客户端对目标服务器的身份和存在是不知情的,只与代理服务器进行通信。

正向代理的应用场景

匿名浏览

正向代理可以隐藏客户端的真实IP地址和身份,使目标服务器只能看到代理服务器的IP地址。这样,客户端可以在访问网站时保护自己的隐私和身份。

访问限制和绕过限制

通过代理,可以设置一些规则,防止客户端访问某些资源。相反,如果某些资源被限制,比如(防火墙),因此可以通过使用正向代理绕过这些限制,访问被屏蔽的内容或服务。

加速和缓存

正向代理服务器可以缓存目标服务器返回的内容。当多个客户端请求相同的资源时,代理服务器可以直接提供缓存的内容,减轻目标服务器的负载,并加快响应速度。

安全性增强

正向代理可以在客户端和目标服务器之间增加一个额外的安全层,可以过滤和阻止恶意请求、病毒、恶意软件等。

反向代理

在维基百科中,反向代理的定义是这样的:

反向代理(Reverse proxy)在电脑网络中是代理服务器的一种。服务器根据客户端的请求,从其关系的一组或多组后端服务器(如Web服务器)上获取资源,然后再将这些资源返回给客户端,客户端只会得知反向代理的IP地址,而不知道在代理服务器后面的服务器集群的存在[1]。
下面我们通过客户端向服务器发起一个HTTP请求这个经典的流程来讲解API网关及其重要的功能。

反向代理的模型示意图如下:

reverse-proxy.png

从上图可以看出,反向代理位于网络和服务器之间,可以把服务器隐藏在反向代理后面。当客户端发起请求时,请求会发送到反向代理服务器,反向代理服务器代表目标服务器向客户端提供服务,并将客户端的请求转发到相应的目标服务器上。

反向代理的的应用场景

负载均衡

反向代理可以将客户端的请求分发给多个目标服务器,以平衡服务器负载。比如 Nginx,可以将用户的请求分发到后端到多个服务器。

缓存

反向代理可以缓存目标服务器返回的内容以及一些静态资源。当多个客户端请求相同的资源时,反向代理可以直接返回缓存的内容,减轻目标服务器的负载,并加快响应时间,提升API性能。

安全性

反向代理可以隐藏目标服务器 IP地址,可以过滤部分恶意请求、DDoS攻击等,并提供Web应用防火墙(WAF)功能,增强网络安全性。

SSL 终止

反向代理可以在代理服务器上终止传入的SSL连接,并将请求转发到目标服务器的非SSL连接上。这样,目标服务器就可以避免处理SSL握手的负担,提高性能。

单一入口

反向代理可以作为单一入口点,将来自多个目标服务器的内容汇聚在一个统一的URL下。这对于构建复杂的应用程序或多服务器架构非常有用。

内容过滤和修改

反向代理可以对请求和响应进行内容过滤和修改。例如,它可以对传入的请求进行访问控制、内容筛选,或者对返回的响应进行内容压缩和修改。

如何选择

正向代理的选择,更多的可以从下面的功能出发:

  • 隐私保护和匿名性
  • 访问控制和绕过限制
  • 缓存和加速
  • 安全增强

反向代理的选择,更多的可以从下面的功能出发:

  • 负载均衡
  • 安全性和隐藏目标服务器
  • SSL 终止
  • 缓存和加速

在实际应用中,正向代理和反向代理也可以结合使用,以发挥各自的优势。比如,某公司拥有多个位于不同地理位置的目标服务器,可以使用反向代理来实现负载均衡和高可用性。同时,为了提供隐私保护和访问控制,可以在客户端和目标服务器之间再添加一个正向代理层。

总结

本文分别分析正向代理和反向代理,正向代理更接近客户端,位于客户端和互联网之间,反向代理更接近服务器,位于互联网和服务器之间。

正向代理无法进行负载均衡和缓存资源优化,反向代理不能直接控制客户端的访问权限。

Squid是一款常见的开源正向代理框架,Nginx是一款常见的开源反向代理框架,同时 Nginx也可以做正向代理。现实工作中,还有很多框架既可以做正向代理,也可以做反向代理。

正向代理和反向代理的选择,我们更多的依据他们的应用场景。

交流学习

最后,把猿哥的座右铭送给你:投资自己才是最大的财富。 如果你觉得文章有帮助,请帮忙转发给更多的好友,或关注:猿java,持续输出硬核文章。

目录
相关文章
|
23天前
|
弹性计算 人工智能 架构师
阿里云携手Altair共拓云上工业仿真新机遇
2024年9月12日,「2024 Altair 技术大会杭州站」成功召开,阿里云弹性计算产品运营与生态负责人何川,与Altair中国技术总监赵阳在会上联合发布了最新的“云上CAE一体机”。
阿里云携手Altair共拓云上工业仿真新机遇
|
15天前
|
存储 关系型数据库 分布式数据库
GraphRAG:基于PolarDB+通义千问+LangChain的知识图谱+大模型最佳实践
本文介绍了如何使用PolarDB、通义千问和LangChain搭建GraphRAG系统,结合知识图谱和向量检索提升问答质量。通过实例展示了单独使用向量检索和图检索的局限性,并通过图+向量联合搜索增强了问答准确性。PolarDB支持AGE图引擎和pgvector插件,实现图数据和向量数据的统一存储与检索,提升了RAG系统的性能和效果。
|
20天前
|
机器学习/深度学习 算法 大数据
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
2024“华为杯”数学建模竞赛,对ABCDEF每个题进行详细的分析,涵盖风电场功率优化、WLAN网络吞吐量、磁性元件损耗建模、地理环境问题、高速公路应急车道启用和X射线脉冲星建模等多领域问题,解析了问题类型、专业和技能的需要。
2572 22
【BetterBench博士】2024 “华为杯”第二十一届中国研究生数学建模竞赛 选题分析
|
18天前
|
人工智能 IDE 程序员
期盼已久!通义灵码 AI 程序员开启邀测,全流程开发仅用几分钟
在云栖大会上,阿里云云原生应用平台负责人丁宇宣布,「通义灵码」完成全面升级,并正式发布 AI 程序员。
|
3天前
|
JSON 自然语言处理 数据管理
阿里云百炼产品月刊【2024年9月】
阿里云百炼产品月刊【2024年9月】,涵盖本月产品和功能发布、活动,应用实践等内容,帮助您快速了解阿里云百炼产品的最新动态。
阿里云百炼产品月刊【2024年9月】
|
2天前
|
存储 人工智能 搜索推荐
数据治理,是时候打破刻板印象了
瓴羊智能数据建设与治理产品Datapin全面升级,可演进扩展的数据架构体系为企业数据治理预留发展空间,推出敏捷版用以解决企业数据量不大但需构建数据的场景问题,基于大模型打造的DataAgent更是为企业用好数据资产提供了便利。
159 2
|
19天前
|
机器学习/深度学习 算法 数据可视化
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码
2024年中国研究生数学建模竞赛C题聚焦磁性元件磁芯损耗建模。题目背景介绍了电能变换技术的发展与应用,强调磁性元件在功率变换器中的重要性。磁芯损耗受多种因素影响,现有模型难以精确预测。题目要求通过数据分析建立高精度磁芯损耗模型。具体任务包括励磁波形分类、修正斯坦麦茨方程、分析影响因素、构建预测模型及优化设计条件。涉及数据预处理、特征提取、机器学习及优化算法等技术。适合电气、材料、计算机等多个专业学生参与。
1570 16
【BetterBench博士】2024年中国研究生数学建模竞赛 C题:数据驱动下磁性元件的磁芯损耗建模 问题分析、数学模型、python 代码
|
21天前
|
编解码 JSON 自然语言处理
通义千问重磅开源Qwen2.5,性能超越Llama
击败Meta,阿里Qwen2.5再登全球开源大模型王座
944 14
|
3天前
|
Linux 虚拟化 开发者
一键将CentOs的yum源更换为国内阿里yum源
一键将CentOs的yum源更换为国内阿里yum源
187 2
|
16天前
|
人工智能 开发框架 Java
重磅发布!AI 驱动的 Java 开发框架:Spring AI Alibaba
随着生成式 AI 的快速发展,基于 AI 开发框架构建 AI 应用的诉求迅速增长,涌现出了包括 LangChain、LlamaIndex 等开发框架,但大部分框架只提供了 Python 语言的实现。但这些开发框架对于国内习惯了 Spring 开发范式的 Java 开发者而言,并非十分友好和丝滑。因此,我们基于 Spring AI 发布并快速演进 Spring AI Alibaba,通过提供一种方便的 API 抽象,帮助 Java 开发者简化 AI 应用的开发。同时,提供了完整的开源配套,包括可观测、网关、消息队列、配置中心等。
711 10