分布式
2022-05-31 本文已影响0人
Zeppelin421
什么是分布式系统
分布式系统是一个硬件或软件组件分布在不同的网络计算机上,彼此之间仅仅通过消息传递进行通信和协调的系统
通俗讲:就是一个业务拆分成多个子业务,分布在不同的服务器节点,共同构成的系统
分布式和集群的区别
- 集群:多个服务器做同一个事情
- 分布式:多个服务器做不同的事情
分布式系统特性
-
分布性
空间中随机分布。这些计算机可以分布在不同的机房,不同的城市甚至不同的国家 -
对等性
分布式系统中的计算机没有主/从之分,组成分布式系统的所有节点都是对等的 -
并发性
同一个分布式系统的多个节点,可能会并发地操作一些共享的资源,如数据库或分布式存储 -
缺乏全局时钟
各个计算机之间是依赖于交换信息来进行互相通信,很难定义两件事的先后顺序,缺乏全局时钟控制序列 -
故障总会发生
组成分布式的计算机,都有可能在某一时刻突然间崩溃。分的计算机越多,可能崩溃的几率就越大 -
处理单点故障
单点SPoF(Single Point of Failure)某个角色或功能只有一台计算机在支撑,这台计算机上出现的故障就是单点故障
分布式面临的问题
-
通信异常
网络本身的不可靠性,因此每次网络通信都会伴随网络不可用的风险,都会导致最终分布式系统无法顺利进行一次网络通信。即使分布式系统各节点之间的网络通信能够正常执行,其延时也会大于单机操作。 -
网络分区
网络之间出现了网络不连通,但各个子网络的内部网络是正常的,从而导致整个系统的网络环境被切分成了若干个孤立的区域,分布式系统就会出现局部小集群。 -
节点故障
节点故障是分布式系统下一个比较常见的问题,是组成分布式系统的服务器节点出现的宕机或僵死现象,根据经验来说,每个节点都有可能出现故障,并且经常发生 -
三态
分布式系统每一次请求与响应存在特有的“三态”概念,即成功、失败和超时 -
重发
分布式系统在发生调用的时候可能会出现失败、超时的情况,这时候需要重新发起调用 -
幂等
一次和多次请求某一个资源对于资源本身应该具有相同的结果,也就是说其任意多次执行对资源本身所产生的影响均与一次执行的影响相同
例如
幂等
select * from t where id = 1;
update t set age = 18 where id = 1;
非幂等
update t set age = age + 1 where id = 1;