反向代理服务器的工作原理
最近有打算研读nginx源代码看到网上介绍nginx可以作为一个反向代理服务器完成负载均衡。所以搜罗了一些关于反向代理服务器的内容整理综合。
一概述
反向代理Reverse Proxy方式是指以代理服务器来接受Internet上的连接请求然后将请求转发给内部网络上的服务器并将从服务器上得到的结果返回给Internet上请求连接的客户端此时代理服务器对外就表现为一个服务器。
通常的代理服务器 只用于代理内部网络对Internet的连接请求客户机必须指定代理服务器,并将本来要直接发送到Web服务器上的http请求发送到代理服务器中。当一个代理服务器能够代理外部网络上的主机访问内部网络时这种代理服务的方式称为反向代理服务。
图1 反向代理服务器的基本原理
二反向代理服务器的工作原理
反向代理服务器通常有两种模型它可以作为内容服务器的替身也可以作为内容服务器集群的负载均衡器。
1 作内容服务器的替身
如果您的内容服务器具有必须保持安全的敏感信息如信用卡号数据库可在防火墙外部设置一个代理服务器作为内容服务器的替身。当外部客户机尝试访问内容服务器时会将其送到代理服务器。实际内容位于内容服务器上在防火墙内部受到安全保护。代理服务器位于防火墙外部在客户机看来就像是内容服务器。
当客户机向站点提出请求时请求将转到代理服务器。然后代理服务器通过防火墙中的特定通路将客户机的请求发送到内容服务器。内容服务器再通过该通道将结果回传给代理服务器。代理服务器将检索到的信息发送给客户机好像代理服务器就是实际的内容服务器参见图2 。如果内容服务器返回错误消息代理服务器会
先行截取该消息并更改标头中列出的任何URL然后再将消息发送给客户机。如此可防止外部客户机获取内部内容服务器的重定向URL。
这样代理服务器就在安全数据库和可能的恶意攻击之间提供了又一道屏障。与有权访问整个数据库的情况相对比就算是侥幸攻击成功作恶者充其量也仅限于访问单个事务中所涉及的信息。未经授权的用户无法访问到真正的内容服务器因为防火墙通路只允许代理服务器有权进行访问。
图2反向代理服务器作为内容服务器的替身
可以配置防火墙路由器使其只允许特定端口上的特定服务器在本例中为其所分配端口上的代理服务器有权通过防火墙进行访问而不允许其他任何机器进出。
2作为内容服务器的负载均衡器
可以在一个组织内使用多个代理服务器来平衡各Web服务器间的网络负载。在此模型中可以利用代理服务器的高速缓存特性创建一个用于负载平衡的服务器池。此时代理服务器可以位于防火墙的任意一侧。如果Web服务器每天都会接收大量的请求则可以使用代理服务器分担Web服务器的负载并提高网络访问效率。
对于客户机发往真正服务器的请求代理服务器起着中间调停者的作用。代理服务器会将所请求的文档存入高速缓存。如果有不止一个代理服务器 DNS可以采用“循环复用法”选择其IP地址随机地为请求选择路由。客户机每次都使用同一个URL但请求所采取的路由每次都可能经过不同的代理服务器。
可以使用多个代理服务器来处理对一个高用量内容服务器的请求这样做的好处是内容服务器可以处理更高的负载并且比其独自工作时更有效率。在初始启动期间代理服务器首次从内容服务器检索文档此后对内容服务器的请求数会大大下降。
图3反向代理服务器作为负载均衡器
Virtono是一家成立于2014年的国外VPS主机商,提供VPS和服务器租用等产品,商家支持PayPal、信用卡、支付宝等国内外付款方式,可选数据中心共7个:罗马尼亚2个,美国3个(圣何塞、达拉斯、迈阿密),英国和德国各1个。目前,商家针对美国圣何塞机房VPS提供75折优惠码,同时,下单后在LET回复订单号还能获得双倍内存的升级。下面以圣何塞为例,分享几款VPS主机配置信息。Cloud VPSC...
木木云怎么样?木木云品牌成立于18年,此为贵州木木云科技有限公司旗下新运营高端的服务器的平台,目前已上线美国中部大盘鸡,母鸡采用E5-267X系列,硬盘全部组成阵列。目前,木木云美国vps进行了优惠促销,1核1G/500M带宽/1T硬盘/4T流量,仅35元/月。点击进入:木木云官方网站地址木木云优惠码:提供了一个您专用的优惠码: yuntue目前我们有如下产品套餐:DV型 1H 1G 500M带宽...
进入6月,各大网络平台都开启了618促销,腾讯云目前也正在开展618云上Go活动,上海/北京/广州/成都/香港/新加坡/硅谷等多个地区云服务器及轻量服务器秒杀,最低年付95元起,参与活动的产品还包括短信包、CDN流量包、MySQL数据库、云存储(标准存储)、直播/点播流量包等等,本轮秒杀活动每天5场,一直持续到7月中旬,感兴趣的朋友可以关注本页。活动页面:https://cloud.tencent...