集群分布式正向代理反向代理概念

Posted log01bq

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了集群分布式正向代理反向代理概念相关的知识,希望对你有一定的参考价值。

集群、分布式、正向代理、反向代理概念


一、集群概念

集群是个物理概念,是指同一个系统,部署在多台服务器上,将很多服务器集中起来一起进行同一种服务,在客户端看来就像是只有一个服务器。集群可以利用多个计算机进行并行计算从而获得很高的计算速度,也可以用多个计算机做备份,从而使得任何一个机器坏了整个系统还是能正常运行。
例如:当用户访问量很大的时候,一台服务器是不够用的,此时就需要进行服务器集群,让多个服务器来共同工作完成一个任务或者提供一种服务。
最常见的三种集群类型
包括负载均衡集群、高可用性集群、高性能集群也就是科学集群。
1)负载均衡集群(LB:load balancing)
负载均衡集群为企业需求提供了更实用的系统。如名称所暗示的,该系统使负载可以在计算机集群中尽可能平均地分摊处理。这样的系统非常适合于运行同一组应用程序的大量用户。每个节点都可以处理一部分负载,并且可以在节点之间动态分配负载,以实现平衡。对于网络流量也是如此。通常,网络服务器应用程序接受了太多入网流量,以致无法迅速处理,这就需要将流量发送给在其它节点上运行的网络服务器应用。还可以根据每个节点上不同的可用资源或网络的特殊环境来进行优化。
2)高可用性集群(HA:High Availability)
高可用性集群的出现是为了使集群的整体服务尽可能可用,以便考虑计算硬件和软件的易错性。如果高可用性集群中的主节点发生了故障,那么这段时间内将由次节点代替它。次节点通常是主节点的镜像,所以当它代替主节点时,它可以完全接管其身份,并且因此使系统环境对于用户是一致的。
3)高性能集群(HP:High Performance)
在集群的这三种基本类型之间,经常会发生混合与交杂。于是,可以发现高可用性集群也可以在其节点之间均衡用户负载,同时仍试图维持高可用性程度。同样,可以从要编入应用程序的集群中找到一个并行集群,它可以在节点之间执行负载均衡。尽管集群系统本身独立于它在使用的软件或硬件,但要有效运行系统时,硬件连接将起关键作用。

二、分布式概念

分布式与集群不同,集群是把多个系统集中在一起提供某种服务,而分布式则侧重将一个系统拆分成多个业务单元,例如一个门户网站里面可能有登录、视频、图片等,每一个都可以拆分出来独立部署,而且每一个都可以弄成集群,视频服务集群,图片服务集群,主系统可以对这些子系统进行调用,子系统之间可以有调用关系也可以没有,看实际业务情况。
也就是说分布式是将不同的业务分布在不同的地方,集群指的是将几台服务器集中在一起,实现同一业务。在现有网络结构之上,负载均衡提供了一种廉价有效的方法扩展服务器带宽和增加吞吐量,加强网络数据处理能力,提高网络的灵活性和可用性。

三、正向代理概念

​意思是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。例如:A要向C请求数据,A通过B进行代理,由B把A的请求转交给C,然后C返回数据给客户端。但是正向代理的时候是知道目标服务器的,而反向代理是不知道目标服务器的。
客户端才能使用正向代理。

四、反向代理概念

反向代理服务器位于用户与目标服务器之间,但是对于用户而言,反向代理服务器就相当于目标服务器,即用户直接访问反向代理服务器就可以获得目标服务器的资源。同时,用户不需要知道目标服务器的地址,也无须在用户端作任何设定。反向代理服务器通常可用来作为Web加速,即使用反向代理作为Web服务器的前置机来降低网络和服务器的负载,提高访问效率。利用反向代理,除了实现负载均衡,还可以实现诸如:SSL加密,静态内容缓存,gzip压缩,减速上传,安全等功能。

五、正向代理与反向代理之间的区别

1、正向代理:类似我们想要访问国外的Google服务器,但是由于访问限制,我们需要找一个代理去访问。换句话说,客户端明确知道要访问的服务器的地址,客户端把请求发送给代理,代理转发给服务器,服务器把响应传给代理,最后代理把响应传给客户端。从而完成代理过程,由此我们可以看到客户端知道服务器是谁,但是服务器并不知道客户端是谁,这就是正向代理,隐藏了客户端的真实信息。正向代理服务器作用于客户端。

2、反向代理:类似我们访问淘宝,由于访问量巨大,淘宝会使用许多台服务器(就是分布式服务器)来支持,但是每个客户端的请求到底由哪一台服务器来响应,我们需要一个代理来决定。换句话说,客户端并不知道要把请求发送给哪一台服务器,但是知道发送给哪一个代理,然后代理依据规则(响应时间,负载均衡等)决定把请求转发给哪一台服务器。由此可以看到,客户端并不知道他访问的服务器是谁,这就是反向代理,隐藏了服务器的真实信息。反向代理服务器作用于服务器端,它在服务器端接收客户端的请求,然后将请求分发给具体的服务器进行处理,然后再将服务器的响应结果反馈给客户端。nginx就是一个反向代理服务器软件。

简单来说,正向代理服务器作用在客户端,反向代理服务器作用在服务器端。

以上是关于集群分布式正向代理反向代理概念的主要内容,如果未能解决你的问题,请参考以下文章

基于Squid和TinyProxy搭建代理集群

Nginx之搭建反向代理实现tomcat分布式集群

HBaseFlumeNginxRedisKafka基础

HBaseFlumeNginxRedisKafka基础

HBaseFlumeNginxRedisKafka基础

服务端搭建高并发分布式架构演进之路