【SpringCloud】如何理解分布式、微服务、集群

一提SpringCloud就会想起分布式、微服务、集群等名词,这几个名词之间有什么关系呢?SpringCloud又是如何实现微服务、分布式和集群的呢?

什么是集群

计算机集群简称集群是一种计算机系统,它通过一组松散集成的计算机软件和/或硬件连接起来高度紧密地协作完成计算工作。在某种意义上,他们可以被看作是一台计算机。集群系统中的单个计算机通常称为节点,通常通过局域网连接,但也有其它的可能连接方式。集群计算机通常用来改进单个计算机的计算速度和/或可靠性。一般情况下集群计算机比单个计算机,比如工作站或超级计算机性能价格比要高得多

什么是分布式

分布式系统是一组计算机,通过网络相互连接传递消息与通信后并协调它们的行为而形成的系统。组件之间彼此进行交互以实现一个共同的目标。

什么是微服务

整个服务的是比较微小的,是一个独立的业务模块,专做改业务的事情,是一个独立的功能单元

区别

从上面的解释来看,我觉得微服务就是把一个整体的系统抽象成一个一个微小的服务,每个服务分别部署在不同的服务器上同时实现了自治就是分布式,每个服务在不同的服务器部署多个然后就构成了集群,这就是我对这三个名词的理解,

SpringCloud如何实现的微服务、分布式、集群

注:一般来说,一个子业务我们称为节点。

CAP理论

在讲SpringCloud之前我们一定要弄懂的一个东西就是CAP

C:数据一致性(consistency)

所有节点拥有数据的最新版本

A:可用性(availability)

数据具备高可用性

P:分区容错性(partition-tolerance)

容忍网络出现分区,分区之间网络不可达。

上面说的有点抽象,具体点来说,C就是说的每个节点部署的服务的数据要保持一致,这样才能使每个服务提供一样的结果,A就是说不管哪个节点出现问题不能服务,都不能影响服务的使用,P是指当出现节点不能通信时,就会出现分区,就是说允许出现这种故障,分区容错性(partition-tolerance)这个是必需的,这是客观存在的。

【SpringCloud】如何理解分布式、微服务、集群
对于分布式可能会出现一些状况,就是某个服务器不连通了,不能使用了