本质上集群部署并没有提高性能快速备案网站快速备案集群,性能看起来提高只是附加属性。集群,一台服务器集群部署性能会提高吗集群的主要目的有两个:避免单点问题扩容单点问题假设没有集群部署,那么就是说只有一台Server对外提供服务,如果这个Server挂掉了,那么所有的客户端就没办法访问了。如果进行了集群部署,假设两台,通过IPhash的方式进行负载均衡,那么当其中一台Server挂掉了,那么只有大概一半的客户端受到影响(如果所有客户端都恰巧hash到了挂掉的那个Server,那就没办法了)。如果路由有故障转移机制,那么基本可以保证一台Server挂掉了,客户端没有影响。扩容再说扩容,一台Server能对外提供的最大负载是一定的。当客户端数量超过了Server的最大负载时,那么就可能导致Server挂掉,或者客户端响应缓慢甚至没有响应的问题。通过集群部署,可以增加最大客户端数量。假设一台Server能同时支持1000个客户端访问,那两台Server理论就能支持2000个客户端同时访问。性能上面说了,集群部署并没有提高性能。集群只是多开通了通道。举个例子,假如有个水池,原来一个水管向水池里注水,集群部署后就是多个水管向水池里注水。单个水管的速度并没有变化,但是流量变大了。看起来性能提高的原因是,性能一般是通过TPS/QPS来定义的,也就是一秒内完成的请求数量。集群后,因为流量大了,那么TPS肯定就高了。但是,TPS/QPS计算的是系统的最大可运行负载。就是一个系统在这个负载下可以正常的长时间对外服务,超过了这个负载就可能导致响应变慢或没有响应、甚至导致服务器直接挂掉。而一般情况下都会做冗余,所以系统基本不会长时间运行在最大可运行负载下。所以一般情况下集群对性能的影响有限,极端情况还可能降低性能。假设一台Server能支持1000个客户端,你部署了两台Server,而实际只有10个客户端进行访问,远达不到单台Server的负载,加上集群需要路由算法,可能性能上就比单台Server稍微慢了一点点。集群,负载均衡和分布式,虽然是不同的概念,但是彼此之间又有联系。01. 集群集群是指有多台服务器,它们做着相同的事情,提供相同的服务区,在调用方看来只有一个服务器对外提供服务,这些服务器组合起来就叫做集群。我们以代码为例:最早的时候,我们的业务都写在一个项目中,比如我们做一个网上商城的项目,客户注册、商品浏览及下单、支付、物流全部都在同一个项目中。但是随着用户的不断增多,一台服务器已经不能满足这么大访问量的时候,我们可以将这个项目部署在多台服务器上,这样就可以让跟多的用户访问我们的网站。虽然这样看起来,我们网站的负载能力更强了,可以让更多的用户访问我们的网站,但是有另外一个问题,就是网站(服务)的入口会有多个,你不可能要求用户能记住你所有服务器的 IP,也不可能申请多个域名挂在不同的服务器上,这时候就需要用到负载均衡了。02. 负载均衡负载均衡可以把用户的请求分发到后端的服务器上,就像这样:这样就变成了统一的入口,然后再做二次分发,将流量按照一定的规则发送到后端的每台服务器上,这个过程就是负载均衡。负载均衡有硬件的实现方式,比如 F5,这是一台硬件设备,也有软件的实现方式,比如 Nginx、LVS 等等;负载均衡策略也有很多,比如轮询法、随机法、随机轮询法、源地址哈希法、最小连接数法、最快响应速度法等等;另外,在微服务架构中,还有一个概念是“客户端负载均衡”,也就是客户端保存着每台服务器的地址,由客户端自己决定去访问哪台服务器。客户端的负载均衡,通常是要和服务注册发现配合使用的。03. 分布式如果所有的代码都写在同一个代码包中,随着需求的增多、业务越来越复杂,这个代码包可能会变得越来越大,越来越难维护;以前三五个开发人员就能维护一个项目,现在是三五百个开发人员一起合作开发;功能模块都在一起,一个功能要升级,整个项目就要跟着一起升级;当我们要做另外一个项目的时候,有一些功能就要重复开发…由于以上种种问题,需要我们将项目进行服务化,分布式部署。集群是多台服务器,每台服务器干相同的事情,那么分布式就是多台机器,每台服务器做不同的事情,它们彼此配合完成工作。当然不是说使用了分布式之后,就不需要负载均衡了,通常两者是配合使用的。我将持续分享Java开发、架构设计、程序员职业发展等方面的见解,希望能得到你的关注。
本文出自快速备案,转载时请注明出处及相应链接。