一、代理机制的发展

最原始的代理就是正向代理。最开始代理就是指的正向代理,后来为了区分反向代理才说正向代理。最原始的代理本来的意思并不是“转发”消息,而是先把消息收下来,然后“伪装”成原始客户端向Web 服务器发送访问请求。

后来产生了反向代理,主要用来代理服务器,在网站架构上伪装成服务器。

来源:漫画编程

思考一件事:租房子

租客、房东、二房东、中介

租客作为客户端,租房请求给到中介,中介就充当了正向代理。中介代理租客与房东协商租房事宜。

租客作为客户端,与二房东协商租房事宜。租客以为二房东就是真实的房东,但其实二房东只是伪装成了房东。这里二房东就是反向代理,他代理房东出租房子。

下面对正向代理和反向代理定义进行描述。

二、正向代理

正向代理(forward proxy):是一个位于客户端和目标服务器之间的服务器(代理服务器),为了从目标服务器取得内容,客户端向代理服务器发送一个请求并指定目标,然后代理服务器向目标服务器转交请求并将获得的内容返回给客户端。

这种代理其实在生活中是比较常见的,比如访问外国网站技术,其用到的就是代理技术。

有时候,用户想要访问某国外网站,该网站无法在国内直接访问,但是我们可以访问到一个代理服务器,这个代理服务器可以访问到这个国外网站。这样呢,用户对该国外网站的访问就需要通过代理服务器来转发请求,并且该代理服务器也会将请求的响应再返回给用户。这个上网的过程就是用到了正向代理。

image-20211217195506676

正向代理,其实是"代理服务器"代理了"客户端",去和"目标服务器"进行交互。

通过正向代理服务器访问目标服务器,目标服务器是不知道真正的客户端是谁的,甚至不知道访问自己的是一个代理(有时候中介也直接冒充租客)。

正向代理的用途:

  1. 突破访问限制

    通过代理服务器,可以突破自身IP访问限制,访问国外网站,教育网等。

    即,租客可以通过中介,来解决无法联系上房东的问题。

  2. 提高访问速度

    通常代理服务器都设置一个较大的硬盘缓冲区,会将部分请求的响应保存到缓冲区中,当其他用户再访问相同的信息时, 则直接由缓冲区中取出信息,传给用户,以提高访问速度。

    即,中介手里留存了很多房源信息和钥匙,可以直接带租客去看房。

  3. 隐藏客户端真实IP

    上网者也可以通过这种方法隐藏自己的IP,免受攻击。

    即,房东并不知道租客的真实身份。PS:但是中介知道了,可能骚扰更多….

三、反向代理

反向代理(reverse proxy):是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

我们在租房子的过程中,除了有些房源需要通过中介以外,还有一些是可以直接通过房东来租的。用户直接找到房东租房的这种情况就是我们不使用代理直接访问国内的网站的情况。

还有一种情况,就是我们以为我们接触的是房东,其实有时候也有可能并非房主本人,有可能是他的亲戚、朋友,甚至是二房东。但是我们并不知道和我们沟通的并不是真正的房东。这种帮助真正的房主租房的二房东其实就是反向代理服务器。这个过程就是反向代理。

对于常用的场景,就是我们在Web开发中用到的负载均衡服务器(二房东),客户端(租客)发送请求到负载均衡服务器(二房东)上,负载均衡服务器(二房东)再把请求转发给一台真正的服务器(房东)来执行,再把执行结果返回给客户端(租客)。

image-20211217195851563

反向代理的用途:

  1. 隐藏服务器真实IP

  2. 负载均衡

  3. 提高访问速度

  4. 提供安全保障

    反向代理服务器可以作为应用层防火墙,为网站提供对基于Web的攻击行为(例如DoS/DDoS)的防护,更容易排查恶意软件等。还可以为后端服务器统一提供加密和SSL加速(如SSL终端代理),提供HTTP访问认证等。

正向代理和反向代理的区别

虽然正向代理服务器和反向代理服务器所处的位置都是客户端和真实服务器之间,所做的事情也都是把客户端的请求转发给服务器,再把服务器的响应转发给客户端,但是二者之间还是有一定的差异的。

  • 正向代理其实是客户端的代理,帮助客户端访问其无法访问的服务器资源。反向代理则是服务器的代理,帮助服务器做负载均衡,安全防护等。
  • 正向代理一般是客户端架设的,比如在自己的机器上安装一个代理软件。而反向代理一般是服务器架设的,比如在自己的机器集群中部署一个反向代理服务器。
  • 正向代理中,服务器不知道真正的客户端到底是谁,以为访问自己的就是真实的客户端。而在反向代理中,客户端不知道真正的服务器是谁,以为自己访问的就是真实的服务器。
  • **正向代理和反向代理的作用和目的不同。正向代理主要是用来解决访问限制问题。而反向代理则是提供负载均衡、安全防护等作用。二者均能提高访问速度。

CDN 网络:全称:Content Delivery Network内容分发网络

解决问题:

  • 尽可能避开互联网上有可能影响数据传输速度和稳定性的瓶颈和缓解(解决网络拥堵的状况);
  • 使得用户可就近取得所需内容;
  • 提高用户访问网站的速度

四、参考文章

  1. 终于有人把正向代理和反向代理解释的明明白白了!