2020-06-07

集群与分布式

首先单机结构:当一个系统的业务量比较小,我们只需要将系统写到一个项目中,然后放到一台服务器中启动,就可以了。但是当业务量逐渐增大,因为硬件的局限,我们发现单机的硬件资源已经无法承载我们需要的业务量,这个时候,集群就出现了。
集群:为了承载更多的业务量 ,突破硬件造成的局限性,于是我们把同一个项目放到了多个服务器上,这些服务器同时运行着同一个项目,这就构成了一个集群,集群中的每个服务器就叫做这个集群“节点”。每个节点都提供同一个服务,那么这个系统的业务承载能力就自然提升了好几倍。
当用户发来请求时,由负载最小的节点来处理请求,这样使得每个节点承受的压力平均起来,这就叫负载均衡。
那么如何判断哪个节点负载最小呢?这就需要在处理用户请求前,有一个”经理”,用户请求交到“经理”手上,“经理”再根据当前“节点”的负载情况,来决定将这个请求交于谁来处理。这个“经理”就是 负载均衡服务器。
集群的优点:就是扩展系统非常容易,如果系统承载不了业务需求量,我们加个“节点”就行了。
分布式:那么如果我们只是系统中的其中一个服务的业务需求量增加了,如果我们通过集群的方式,是可以解决问题,但是这样的话未免造成了过多的资源浪费。这个时候,分布式便提供了很好的解决方案。
所谓分布式,就是将一个完整的系统,根据其业务功能,将其分解成一个个的子系统,每个子系统在一台服务器上独立运行,子系统之间通过rpc的方式相互通信。而这每个子系统,就叫做一个服务。这样做也增加了另一个好处,就是这个服务复用性极高。
例如:一个系统中有用户服务,产品服务,日志服务等,每个服务都是一个独立的系统,是一个独立运行的项目,那么这个时候,如果另外一个系统同样需要用户服务,我们可以将独立运行的用户服务同样用到这个系统中去,而不需要二次开发。
分布式的优点:
1.降低耦合性,可独立开发,独立测试,开发效率大大提升。
2.易于针对扩展,如,当用户量突然大增,我们只需要先增大扩展用户服务即可,不需要一次性对整个系统进行扩展。
3.独立性强,由于一个服务就是一个独立的项目,单独运行在一个服务器上,那么当某个某个服务宕机时,在关联性不大的情况下,其他的服务照样可以正常运行,不会造成整个系统的瘫痪。
4.可维护性高,由于模块的独立性,使我们定位问题的范围缩小,可以更快,更精准的定位到bug,及时做出修复

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值