精华内容
下载资源
问答
  • Nginx是一款自由的、开源的、高性能的HTTP服务器 反向代理 服务器;同时也是一个IMAP、POP3、SMTP代理服务器;Nginx可以作为一个HTTP服务器进行网站的发布处理,另外Nginx可以作为反向代理进行负载均衡的实现。 ...
  • 正向代理 就是假设有一个内网 内网有两台机器,这两台机器只有 a 可以上网 b 不能上网,但是 a b 通过网络相连接 这时如果 b 想访问外网,就可以通过 a 来正向代理访问外网 正向代理就是在内网中模拟目标服务器,...
  • 计算机网络中的代理又分为正向代理和反向代理正向代理很简单,就是客户端不直接访问服务端,而是通过一个中间人访问(中间人先代替客户端向服务端获取到数据,再将获取到的数据返回给客户端),很容易理解吧,那...

    一文说清楚正向代理与反向代理的区别

    什么是正向代理?什么是反向代理?它们的区别是什么?看完本文就清楚了…

    首先,从字面上理解,代理的意思是代替办理,就是一方委托另一方办事,在计算机网络的世界里,代理通常是指客户端与服务端之间的中介。

    计算机网络中的代理又分为正向代理和反向代理,正向代理很简单,就是客户端不直接访问服务端,而是通过一个中间人访问(中间人先代替客户端向服务端获取到数据,再将获取到的数据返回给客户端),很容易理解吧,那很多人会问,为什么客户端要“脱了裤子放屁”,不直接访问服务端呢?通常有两种原因:

    1.因某些你懂的原因,客户端所在网络限制访问服务端了;
    2.因某些特殊原因,服务端不允许某些来源的客户端访问。

    举个粟子:A村子和B村子关系不好,所以A村设了限制,不允许A村民去B村小卖部买玉米,或者B村子小卖部不卖玉米给A村民。但A村民又想要B村子小卖部玉米,那怎么办呢?A村民可以委托C村子的人代替自己去B村子买东西,带回来后再交给自己,这就是正向代理。示意图如下:
    在这里插入图片描述

    图片来源:自己画的

    这种结构的特点是:服务端不知道自己的真正客户是谁,它接触的客户是代理,但客户是知道真正提供服务的是谁(是B小卖部而非代理),正向代理是客户端无法直接访问(或想匿名访问)服务端的解决方案, 委托方是客户端!

    而关于反向代理,很多人都觉得难以理解,因为正常的思维,既然正向代理是客户端向服务端获取数据的中介,那反向很自然就应该是服务端向客户端获取数据的中介了,然鹅事实并非如此,他们是有很大差别的,这是理解的难点。先来看一下下面这张图:
    在这里插入图片描述

    图片来源:自己画的

    B村有很多村民都生产玉米(假设生产的玉米是无差别的),但分别单独对外售卖玉米很麻烦,因为客户不知道哪家有,也不清楚哪家的量有多少,所以他们全部委托给B村小卖部销售(注意: 委托方是服务端!),由小卖部统一对外服务。买玉米的客户不清楚玉米是哪家的,只管直接向小卖部购买就可以了,这就是反向代理。

    这种结构的特点是:客户端不知道谁是真正的服务端(供应商),反向代理往往会根据一定的策略将请求转发到最合适的服务器处理,例如按服务器闲忙情况分配,咦,听起来是不是很像负载均衡的策略?没错,反向代理经常应用于实现负载均衡场景,Nginx等Web服务器支持反向代理功能并被广泛应用于实现负载均衡。

    总的来说:所以虽然这两种代理方式名字相近,但目的及应用场景上天差地别:

    • 从功能来看:
      正向代理是客户端不能(不便)直接访问服务端的解决方案
      反向代理是多个服务端统一对外提供服务的解决方案
    • 从目标客户角度看
      正向代理的委托方是客户端,代理向客户端(单次是1个)提供服务
      反向代理的委托方是服务端,代理向多个(通常是多个,也可以单个)服务端提供服务
    • 从可见性的角度来看
      正向代理对客户端可见,是客户端主动选择的结果(可选可不选,服务端只能被动选择),客户端可以选择直接访问(是否能访问得到是另一回事),也可以选择通过代理访问
      反向代理对客户端不可见,是客户端被动选择的结果(是服务端主动选择的结果),意思是:客户端是不知道目前访问的服务是否使用了反向代理的

    PS:有时候,这两种代理方式会在一次网络请求中并存,如下图所示:
    在这里插入图片描述

    *图片来源:自己画的*

    大家各司其职,是完全没有冲突的

    小伙伴看懂了吗?

    展开全文
  • Nginx 相关介绍(正向代理和反向代理区别)

    万次阅读 多人点赞 2019-05-01 14:43:12
    通常情况下,我们在实际项目操作时,正向代理和反向代理很有可能会存在在一个应用场景中,正向代理代理客户端的请求去访问目标服务器,目标服务器是一个反向代理服务器,反向代理了多台真实的业务处理服务器。...

    Nginx的产生

    没有听过Nginx?那么一定听过它的"同行"Apache吧!Nginx同Apache一样都是一种WEB服务器。基于REST架构风格,以统一资源描述符(Uniform Resources Identifier)URI或者统一资源定位符(Uniform Resources Locator)URL作为沟通依据,通过HTTP协议提供各种网络服务。

    然而,这些服务器在设计之初受到当时环境的局限,例如当时的用户规模,网络带宽,产品特点等局限并且各自的定位和发展都不尽相同。这也使得各个WEB服务器有着各自鲜明的特点。

    Apache的发展时期很长,而且是毫无争议的世界第一大服务器。它有着很多优点:稳定、开源、跨平台等等。它出现的时间太长了,它兴起的年代,互联网产业远远比不上现在。所以它被设计为一个重量级的。它不支持高并发的服务器。在Apache上运行数以万计的并发访问,会导致服务器消耗大量内存。操作系统对其进行进程或线程间的切换也消耗了大量的CPU资源,导致HTTP请求的平均响应速度降低。

    这些都决定了Apache不可能成为高性能WEB服务器,轻量级高并发服务器Nginx就应运而生了。

    俄罗斯的工程师Igor Sysoev,他在为Rambler Media工作期间,使用C语言开发了Nginx。Nginx作为WEB服务器一直为Rambler Media提供出色而又稳定的服务。

    然后呢,Igor Sysoev将Nginx代码开源,并且赋予自由软件许可证。

    由于:

    • Nginx使用基于事件驱动架构,使得其可以支持数以百万级别的TCP连接
    • 高度的模块化和自由软件许可证使得第三方模块层出不穷(这是个开源的时代啊~)
    • Nginx是一个跨平台服务器,可以运行在Linux,Windows,FreeBSD,Solaris, AIX,Mac OS等操作系统上
    • 这些优秀的设计带来的极大的稳定性

    所以,Nginx火了!

    Nginx的用武之地

    Nginx是一款自由的、开源的、高性能的HTTP服务器和反向代理服务器;同时也是一个IMAP、POP3、SMTP代理服务器;Nginx可以作为一个HTTP服务器进行网站的发布处理,另外Nginx可以作为反向代理进行负载均衡的实现。

    关于代理

    说到代理,首先我们要明确一个概念,所谓代理就是一个代表、一个渠道;

    此时就涉及到两个角色,一个是被代理角色,一个是目标角色,被代理角色通过这个代理访问目标角色完成一些任务的过程称为代理操作过程;如同生活中的专卖店~客人到adidas专卖店买了一双鞋,这个专卖店就是代理,被代理角色就是adidas厂家,目标角色就是用户。

    正向代理

    说反向代理之前,我们先看看正向代理,正向代理也是大家最常接触的到的代理模式,我们会从两个方面来说关于正向代理的处理模式,分别从软件方面和生活方面来解释一下什么叫正向代理。

    在如今的网络环境下,我们如果由于技术需要要去访问国外的某些网站,此时你会发现位于国外的某网站我们通过浏览器是没有办法访问的,此时大家可能都会用一个代理进行访问,代理的方式主要是找到一个可以访问国外网站的代理服务器,我们将请求发送给代理服务器,代理服务器去访问国外的网站,然后将访问到的数据传递给我们!

    上述这样的代理模式称为正向代理,正向代理最大的特点是客户端非常明确要访问的服务器地址;服务器只清楚请求来自哪个代理服务器,而不清楚来自哪个具体的客户端;正向代理模式屏蔽或者隐藏了真实客户端信息。来看个示意图(我把客户端和正向代理框在一块,同属于一个环境,后面我有介绍):

    客户端必须设置正向代理服务器,当然前提是要知道正向代理服务器的IP地址,还有代理程序的端口。如图。

    总结来说:正向代理,"它代理的是客户端",是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端必须要进行一些特别的设置才能使用正向代理。

    正向代理的用途:
    (1)访问原来无法访问的资源,如Google
    (2) 可以做缓存,加速访问资源
    (3)对客户端访问授权,上网进行认证
    (4)代理可以记录用户访问记录(上网行为管理),对外隐藏用户信息

    反向代理

    明白了什么是正向代理,我们继续看关于反向代理的处理方式,举例如我大天朝的某宝网站,每天同时连接到网站的访问人数已经爆表,单个服务器远远不能满足人民日益增长的购买欲望了,此时就出现了一个大家耳熟能详的名词:分布式部署;也就是通过部署多台服务器来解决访问人数限制的问题;某宝网站中大部分功能也是直接使用Nginx进行反向代理实现的,并且通过封装Nginx和其他的组件之后起了个高大上的名字:Tengine,有兴趣的童鞋可以访问Tengine的官网查看具体的信息:http://tengine.taobao.org/。那么反向代理具体是通过什么样的方式实现的分布式的集群操作呢,我们先看一个示意图(我把服务器和反向代理框在一块,同属于一个环境,后面我有介绍):

    通过上述的图解大家就可以看清楚了,多个客户端给服务器发送的请求,Nginx服务器接收到之后,按照一定的规则分发给了后端的业务处理服务器进行处理了。此时~请求的来源也就是客户端是明确的,但是请求具体由哪台服务器处理的并不明确了,Nginx扮演的就是一个反向代理角色。

    客户端是无感知代理的存在的,反向代理对外都是透明的,访问者并不知道自己访问的是一个代理。因为客户端不需要任何配置就可以访问。

    反向代理,"它代理的是服务端",主要用于服务器集群分布式部署的情况下,反向代理隐藏了服务器的信息。

    反向代理的作用:
    (1)保证内网的安全,通常将反向代理作为公网访问地址,Web服务器是内网
    (2)负载均衡,通过反向代理服务器来优化网站的负载

    项目场景

    通常情况下,我们在实际项目操作时,正向代理和反向代理很有可能会存在在一个应用场景中,正向代理代理客户端的请求去访问目标服务器,目标服务器是一个反向代理服务器,反向代理了多台真实的业务处理服务器。具体的拓扑图如下:

    二者区别

    截了一张图来说明正向代理和反向代理二者之间的区别,如图。

    图解:

    在正向代理中,Proxy和Client同属于一个LAN(图中方框内),隐藏了客户端信息;

    在反向代理中,Proxy和Server同属于一个LAN(图中方框内),隐藏了服务端信息;

    实际上,Proxy在两种代理中做的事情都是替服务器代为收发请求和响应,不过从结构上看正好左右互换了一下,所以把后出现的那种代理方式称为反向代理了。

    负载均衡

    我们已经明确了所谓代理服务器的概念,那么接下来,Nginx扮演了反向代理服务器的角色,它是以依据什么样的规则进行请求分发的呢?不同的项目应用场景,分发的规则是否可以控制呢?

    这里提到的客户端发送的、Nginx反向代理服务器接收到的请求数量,就是我们说的负载量。

    请求数量按照一定的规则进行分发到不同的服务器处理的规则,就是一种均衡规则。

    所以~将服务器接收到的请求按照规则分发的过程,称为负载均衡。

    负载均衡在实际项目操作过程中,有硬件负载均衡和软件负载均衡两种,硬件负载均衡也称为硬负载,如F5负载均衡,相对造价昂贵成本较高,但是数据的稳定性安全性等等有非常好的保障,如中国移动中国联通这样的公司才会选择硬负载进行操作;更多的公司考虑到成本原因,会选择使用软件负载均衡,软件负载均衡是利用现有的技术结合主机硬件实现的一种消息队列分发机制。

    Nginx支持的负载均衡调度算法方式如下:

    1. weight轮询(默认):接收到的请求按照顺序逐一分配到不同的后端服务器,即使在使用过程中,某一台后端服务器宕机,Nginx会自动将该服务器剔除出队列,请求受理情况不会受到任何影响。 这种方式下,可以给不同的后端服务器设置一个权重值(weight),用于调整不同的服务器上请求的分配率;权重数据越大,被分配到请求的几率越大;该权重值,主要是针对实际工作环境中不同的后端服务器硬件配置进行调整的。
    2. ip_hash:每个请求按照发起客户端的ip的hash结果进行匹配,这样的算法下一个固定ip地址的客户端总会访问到同一个后端服务器,这也在一定程度上解决了集群部署环境下session共享的问题。
    3. fair:智能调整调度算法,动态的根据后端服务器的请求处理到响应的时间进行均衡分配,响应时间短处理效率高的服务器分配到请求的概率高,响应时间长处理效率低的服务器分配到的请求少;结合了前两者的优点的一种调度算法。但是需要注意的是Nginx默认不支持fair算法,如果要使用这种调度算法,请安装upstream_fair模块。
    4. url_hash:按照访问的url的hash结果分配请求,每个请求的url会指向后端固定的某个服务器,可以在Nginx作为静态服务器的情况下提高缓存效率。同样要注意Nginx默认不支持这种调度算法,要使用的话需要安装Nginx的hash软件包。

     几种常用web服务器对比

    对比项ApacheNginxLighttpd
    Proxy代理非常好非常好一般
    Rewriter非常好一般
    Fcgi不好非常好
    热部署不支持支持不支持
    系统压力很大很小比较小
    稳定性非常好不好
    安全性一般一般
    静态文件处理一般非常好
    反向代理一般非常好一般

     

    原文链接:https://www.cnblogs.com/wcwnina/p/8728391.html

    展开全文
  • 图解正向代理和反向代理

    千次阅读 2019-04-03 23:56:37
    套用古龙武侠小说套路来说,...常用的代理技术分为正向代理反向代理和透明代理。本文就是针对这三种代理来讲解一些基本原理和具体的适用范围,便于大家更深入理解代理服务技术。 一、正向代理(Forward Proxy) &nbs...

    套用古龙武侠小说套路来说,代理服务技术是一门很古老的技术,是在互联网早期出现就使用的技术。一般实现代理技术的方式就是在服务器上安装代理服务软件,让其成为一个代理服务器,从而实现代理技术。常用的代理技术分为正向代理、反向代理和透明代理。本文就是针对这三种代理来讲解一些基本原理和具体的适用范围,便于大家更深入理解代理服务技术。

    一、正向代理(Forward Proxy)
    一般情况下,如果没有特别说明,代理技术默认说的是正向代理技术。关于正向代理的概念如下:
    正向代理(forward)是一个位于客户端【用户A】和原始服务器(origin server)【服务器B】之间的服务器【代理服务器Z】,为了从原始服务器取得内容,用户A向代理服务器Z发送一个请求并指定目标(服务器B),然后代理服务器Z向服务器B转交请求并将获得的内容返回给客户端。客户端必须要进行一些特别的设置才能使用正向代理。如下图1.1
    在这里插入图片描述
    从上面的概念中,我们看出,文中所谓的正向代理就是代理服务器替代访问方【用户A】去访问目标服务器【服务器B】
    这就是正向代理的意义所在。而为什么要用代理服务器去代替访问方【用户A】去访问服务器B呢?这就要从代理服务器使用的意义说起。
    使用正向代理服务器作用主要有以下几点:
    1、访问本无法访问的服务器B,如下图1.2
    在这里插入图片描述
    我们抛除复杂的网络路由情节来看图1.2,假设图中路由器从左到右命名为R1,R2
    假设最初用户A要访问服务器B需要经过R1和R2路由器这样一个路由节点,如果路由器R1或者路由器R2发生故障,那么就无法访问服务器B了。但是如果用户A让代理服务器Z去代替自己访问服务器B,由于代理服务器Z没有在路由器R1或R2节点中,而是通过其它的路由节点访问服务器B,那么用户A就可以得到服务器B的数据了。
    现实中的例子就是“翻墙”。不过自从***技术被广泛应用外,“翻墙”不但使用了传统的正向代理技术,有的还使用了***技术。

    2、加速访问服务器B
    这种说法目前不像以前那么流行了,主要是带宽流量的飞速发展。早期的正向代理中,很多人使用正向代理就是提速。还是如图1.2
    假设用户A到服务器B,经过R1路由器和R2路由器,而R1到R2路由器的链路是一个低带宽链路。而用户A到代理服务器Z,从代理服务器Z到服务器B都是高带宽链路。那么很显然就可以加速访问服务器B了。

    3、Cache作用
    Cache(缓存)技术和代理服务技术是紧密联系的(不光是正向代理,反向代理也使用了Cache(缓存)技术。还如上图所示,如果在用户A访问服务器B某数据J之前,已经有人通过代理服务器Z访问过服务器B上得数据J,那么代理服务器Z会把数据J保存一段时间,如果有人正好取该数据J,那么代理服务器Z不再访问服务器B,而把缓存的数据J直接发给用户A。这一技术在Cache中术语就叫Cache命中。如果有更多的像用户A的用户来访问代理服务器Z,那么这些用户都可以直接从代理服务器Z中取得数据J,而不用千里迢迢的去服务器B下载数据了。

    4、客户端访问授权
    这方面的内容现今使用的还是比较多的,例如一些公司采用ISA SERVER做为正向代理服务器来授权用户是否有权限访问互联网,挼下图1.3
    在这里插入图片描述
    图1.3防火墙作为网关,用来过滤外网对其的访问。假设用户A和用户B都设置了代理服务器,用户A允许访问互联网,而用户B不允许访问互联网(这个在代理服务器Z上做限制)这样用户A因为授权,可以通过代理服务器访问到服务器B,而用户B因为没有被代理服务器Z授权,所以访问服务器B时,数据包会被直接丢弃。
    5、隐藏访问者的行踪
    如下图1.4 我们可以看出服务器B并不知道访问自己的实际是用户A,因为代理服务器Z代替用户A去直接与服务器B进行交互。如果代理服务器Z被用户A完全控制(或不完全控制),会惯以“肉鸡”术语称呼。
    在这里插入图片描述
    (图1.4)

    我们总结一下 正向代理是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端必须设置正向代理服务器,当然前提是要知道正向代理服务器的IP地址,还有代理程序的端口。

    二、反向代理(reverse proxy)
    反向代理正好与正向代理相反,对于客户端而言代理服务器就像是原始服务器,并且客户端不需要进行任何特别的设置。客户端向反向代理的命名空间(name-space)中的内容发送普通请求,接着反向代理将判断向何处(原始服务器)转交请求,并将获得的内容返回给客户端。
    使用反向代理服务器的作用如下:
    1、 保护和隐藏原始资源服务器
    如下图2.1在这里插入图片描述
    用户A始终认为它访问的是原始服务器B而不是代理服务器Z,但实用际上反向代理服务器接受用户A的应答,从原始资源服务器B中取得用户A的需求资源,然后发送给用户A。由于防火墙的作用,只允许代理服务器Z访问原始资源服务器B。尽管在这个虚拟的环境下,防火墙和反向代理的共同作用保护了原始资源服务器B,但用户A并不知情。
    2、 负载均衡
    如下图2.2在这里插入图片描述
    当反向代理服务器不止一个的时候,我们甚至可以把它们做成集群,当更多的用户访问资源服务器B的时候,让不同的代理服务器Z(x)去应答不同的用户,然后发送不同用户需要的资源。
    当然反向代理服务器像正向代理服务器一样拥有CACHE的作用,它可以缓存原始资源服务器B的资源,而不是每次都要向原始资源服务器B请求数据,特别是一些静态的数据,比如图片和文件,如果这些反向代理服务器能够做到和用户X来自同一个网络,那么用户X访问反向代理服务器X,就会得到很高质量的速度。这正是CDN技术的核心。如下图2.3
    在这里插入图片描述
    我们并不是讲解CDN,所以去掉了CDN最关键的核心技术智能DNS。只是展示CDN技术实际上利用的正是反向代理原理这块。
    反向代理结论与正向代理正好相反,对于客户端而言它就像是原始服务器,并且客户端不需要进行任何特别的设置。客户端向反向代理的命名空间(name-space)中的内容发送普通请求,接着反向代理将判断向何处(原始服务器)转交请求,并将获得的内容返回给客户端,就像这些内容原本就是它自己的一样。

    基本上,网上做正反向代理的程序很多,能做正向代理的软件大部分也可以做反向代理。开源软件中最流行的就是squid,既可以做正向代理,也有很多人用来做反向代理的前端服务器。另外MS ISA也可以用来在WINDOWS平台下做正向代理。反向代理中最主要的实践就是WEB服务,近些年来最火的就是Nginx了。网上有人说NGINX不能做正向代理,其实是不对的。NGINX也可以做正向代理,不过用的人比较少了。

    三、透明代理
    如果把正向代理、反向代理和透明代理按照人类血缘关系来划分的话。那么正向代理和透明代理是很明显堂亲关系,而正向代理和反向代理就是表亲关系了 。
    透明代理的意思是客户端根本不需要知道有代理服务器的存在,它改编你的request fields(报文),并会传送真实IP。注意,加密的透明代理则是属于匿名代理,意思是不用设置使用代理了。
    透明代理实践的例子就是时下很多公司使用的行为管理软件。如下图3.1
    在这里插入图片描述
    (图3.1)

    用户A和用户B并不知道行为管理设备充当透明代理行为,当用户A或用户B向服务器A或服务器B提交请求的时候,透明代理设备根据自身策略拦截并修改用户A或B的报文,并作为实际的请求方,向服务器A或B发送请求,当接收信息回传,透明代理再根据自身的设置把允许的报文发回至用户A或B,如上图,如果透明代理设置不允许访问服务器B,那么用户A或者用户B就不会得到服务器B的数据。

    和传统代理服务器可以保护浏览器安全一样, 反向代理服务器也具有保护网站安全的作用,来自互联网的访问请求必须经过代理服务器,相当于在Web 服务器和可能的网
    络攻击之间建立了一个屏障。
    除了安全功能, 代理服务器也可以通过配置缓存功能加速Web 请求。当用户第一次
    访问静态内容的时候, 静态内容就被缓存在反向代理服务器上, 这样当其他用户访问该
    静态内容的时候, 就可以直接从反向代理服务器返回,加速Web 请求响应速度, 减轻Web服务器负载压力。事实上, 有些网站会把动态内容也缓存在代理服务器上,比如维基百科及某些博客论坛网站, 把热门词条、帖子飞博客缓存在反向代理服务器上加速用户访问速度, 当这些动态内容有变化时,通过内部通知机制通知反向代理缓存失效, 反向代理会重新加载最新的动态内容再次缓存起来。
    此外,反向代理也可以实现负载均衡的功能,而通过负载均衡构建的应用集群可以
    提高系统总体处理能力, 进而改善网站高并发情况下的性能。

    原文:https://blog.51cto.com/z00w00/1031287

    其他不错文章分享:

    https://www.cnblogs.com/Anker/p/6056540.html

    https://blog.csdn.net/m13666368773/article/details/8060481

    展开全文
  • Nginx是有俄罗斯人伊戈尔·赛索耶夫(Igor Sysoev)为俄罗斯访问量第二的rambler.ru站点开发的轻量级Web服务器,同时也是一个非常高效的反向代理、负载平衡服务器。在性能上,Nginx占用很少的系统资源,能支持更多的...

            Nginx是有俄罗斯人伊戈尔·赛索耶夫(Igor Sysoev)为俄罗斯访问量第二的rambler.ru站点开发的轻量级Web服务器,同时也是一个非常高效的反向代理、负载平衡服务器。在性能上,Nginx占用很少的系统资源,能支持更多的并发连接,达到更高的访问效率;在功能上,Nginx是优秀的代理服务器和负载均衡服务器;在安装配置上,Nginx安装简单、配置灵活。

    本文主要从正向代理,反向代理和负载均衡三个方面简单介绍Nginx的工作原理。

    正向代理

    正向代理

            正向代理也可以理解为客户端代理,Nginx代替客户端向明确的服务器发送请求,对于服务器来说客户端完全透明。如上图所示,客户机数量的多少不重要,重要的是客户机一定是知道将要访问的是哪台服务器。而且代理服务器是可以不知道客户机要访问哪里的,代理服务器可以从客户机的请求中解析出目标服务器的地址。

           在生活中很多场景都可以形象的展现正向代理的例子。比如客户去某品牌专卖店购物,在客户购买产品这个过程中,专卖店就是个代理的角色。对于客户而言,客户明确指明了购买哪个厂家的具体哪个产品,专卖店需要明确的去这个厂家取货就可以了。上述这样的代理模式称为正向代理。

            在软件应用的场景来说FQ最能体现这个正向代理模式。正向代理最大的特点是客户端非常明确要访问的服务器地址;服务器只清楚请求来自哪个代理服务器,而不清楚来自哪个具体的客户端;正向代理模式屏蔽或者隐藏了真实客户端信息。

    反向代理

    方向代理

            反向代理也可以理解为服务端代理,Nginx代理服务器为客户端提供服务,对应客户端来说服务端完全透明。如上图所示,服务器数量的多少不重要,重要的代理服务器需要知道所有应用服务器的信息,并且给客户机提供服务的服务器最终是由代理服务器分配实现的。
           在生活中也有很多场景可以形象的展现方向代理的例子。我们以海外代购为例,客户告诉代购人需要某件产品,代购人出国后就去各个店铺挑选客户需要的产品,最终交给客户时客户是完全不知道自己的产品是来自哪家店铺。也就是说在这个过程中对于客户端而言店铺完全透明。这样的代理模式就称为反向代理。

            在软件应用场景来说负载均衡最能体现反向代理模式。反向代理最大的特点是客户端并不知道具体要访问的服务器地址,最终由哪个服务器提供服务有反向代理服务来决定。反向代理模式屏蔽或者隐藏了真实的服务端信息。

    负载均衡

            Nginx就是性能非常好的反向代理服务器,用来做负载均衡。什么是负载均衡呢?负载均衡,英文名称为Load Balance,就是原本由一个人来说的工作,分散到了很多人身上,让大家都可以很轻松的完成工作。由于Nginx反向代理服务器转发请求在HTTP协议层面,因此通过Nginx实现的负载均衡也叫应用层负载均衡。优点是部署简单,网络的依赖非常小,并发能力高(5w次,一般服务器也有2K次的并发),通过端口检测到服务器内部的故障,缺点是不支持URL来检测,session的保持和cookie的引导能力欠缺。

    总结:当然严格的来说,正向代理和反向代理是通常是融合在一起使用的,互为补充的。我这里算是强行将其概念化只是为了便于理解。

    展开全文
  • 正向代理和反向代理有什么区别

    千次阅读 2020-01-02 13:04:23
    正向代理:在客户端(浏览器)配置代理服务器,通过代理...客户端和正向代理服务器处在同一个局域网. 反向代理:客户端无法感知代理的存在,通过代理服务器来接受internet上的连接请求,然后将请求转发给内部网络...
  • 正向代理和反向代理的区别

    千次阅读 2018-10-09 14:58:30
    正向代理是一个位于客户端目标服务器之间的代理服务器(中间服务器)。为了从原始服务器取得内容,客户端向代理服务器发送一个请求,并且指定目标服务器,之后代理向目标服务器转交并且将获得的内容返回给客户端。...
  • 正向代理和反向代理总结

    千次阅读 多人点赞 2019-02-14 16:41:13
     最近工作中用到反向代理,发现网络代理的玩法还真不少,网络背后有很多需要去学习。而在此之前仅仅使用了过代理软件,曾经为了访问google,使用了代理软件,需要在浏览器中配置代理的地址。我只知道有代理这个概念...
  • Nginx 正向代理和反向代理

    万次阅读 2018-04-20 09:56:53
    最近在捣腾代理,要做个内网yum源代理,之前没接触过代理这些个东西,折腾完记录一下吧。 一、下载源码 目前Nginx一般都是使用源码编译,没有现成的rpm包。下载网址:http://nginx.org/download/。里面有各个...
  • 正向代理和反向代理

    千次阅读 热门讨论 2021-03-07 21:29:25
    正向代理是不清楚客户是谁,反向代理是不清楚服务器是谁。 买口红的小栗子: 正向代理:用户要买口红,代理去买了口红了,但是专卖店不知道是哪个客户买了口红。这个是代理和客户是一家人。 反向代理:用户通过代理...
  • 正向代理:我们访问挂上代理去访问一个网站: 方向代理:服务器用代理服务器接受请求:
  • nginx--正向代理和反向代理(一)

    千次阅读 2020-08-07 15:08:03
    一、正向代理和反向代理的区别 代理其实就是一个中介,A和B本来可以直连,中间插入一个C,C就是中介。 (1)、正向代理正向代理就是顺着请求的方向进行的代理,即代理服务器他是由你配置为你服务,去请求目标...
  • 从渗透的角度分析正向代理和反向代理 正向代理服务器一般配置要求低,主要充当流量转发 如搭建vps服务器,隐藏攻击者ip,上外网等 反向代理服务器一般配置要求高,主要充当数据处理 如肉鸡充当服务器或cdn(内容分发...
  • java的正向代理和反向代理

    千次阅读 2018-04-13 17:25:21
    一、正向代理在我们生活中有很多代理的例子: 租房子找中介,中介就是一个代理。 打扫房屋找清洁公司,清洁公司就是一个代理。 相亲找媒婆,媒婆就是一个代理。要了解java的正向代理先来以下的一个例子: 我是一...
  • 正向代理( Forward Proxy ):是一个位于客户端原始服务器之间的服务器,为了从原始服务器取得内容, 客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。...
  • nginx正向代理和反向代理

    千次阅读 2018-03-04 10:37:41
    一、正向代理 正向代理类似一个跳板机,代理访问外部资源。设定我是一个用户(客户端)现在要请求一个web站点,我的电脑配置了正向代理,客户端先请求代理服务器,由代理服务器去访问指定的网页(或者地址),代理...
  • 正向代理    是一个位于客户端原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给...
  • 通常来说,正向代理和反向代理都是一种中间人提供的服务,今天就给大家盘点以下正向代理和反向代理的用途。 正向代理的典型用途是为防火墙内的局域网客户提供访问互联网的途径,可用于访问被禁止访问的网站、政府、...
  • Linux系统中的正向代理和反向代理

    千次阅读 2018-05-30 09:34:26
    什么是正向代理和反向代理正向代理,是一个位于客户端和原始服务器之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容...
  • 理解了C-S架构,理解了正向代理反向代理以后,自然会懂B-S架构是什么, 就好比高中物理说不存在向心力,那也只是在高中物理的范畴之内为了学生更好的理解而说的 还有就是先“不严谨的认为ip是每人都不同的”,理解了...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 22,004
精华内容 8,801
关键字:

正向代理和反向代理