概念:
集群是个物理形态,分布式是个工做方式。缓存
- 分布式:一个业务分拆多个子业务,部署在不一样的服务器上
- 集群:同一个业务,部署在多个服务器上
1:分布式是指将不一样的业务分布在不一样的地方。而集群指的是将几台服务器集中在一块儿,实现同一业务。服务器
分布式中的每个节点,均可以作集群。而集群并不必定就是分布式的。session
举例:就好比新浪网,访问的人多了,他能够作一个群集,前面放一个响应服务器,后面几台服务器完成同一业务,若是有业务访问的时候,响应服务器看哪台服务器的负载不是很重,就将给哪一台去完成。架构
而分布式,从窄意上理解,也跟集群差很少,可是它的组织比较松散,不像集群,有一个组织性,一台服务器垮了,其它的服务器能够顶上来。并发
分布式的每个节点,都完成不一样的业务,一个节点垮了,那这个业务就不可访问了。负载均衡
2:简单说,分布式是以缩短单个任务的执行时间来提高效率的,而集群则是经过提升单位时间内执行的任务数来提高效率。分布式
例如:若是一个任务由 10 个子任务组成,每一个子任务单独执行需 1 小时,则在一台服务器上执行该任务需 10 小时。微服务
采用分布式方案,提供 10 台服务器,每台服务器只负责处理一个子任务,不考虑子任务间的依赖关系,执行完这个任务只需一个小时。(这种工做模式的一个典型表明就是 Hadoop 的 Map/Reduce 分布式计算模型)oop
而采用集群方案,一样提供 10 台服务器,每台服务器都能独立处理这个任务。假设有 10 个任务同时到达,10 个服务器将同时工做,1 小时后,10 个任务同时完成,这样,整身来看,仍是 1 小时内完成一个任务!url
好的设计应该是分布式和集群的结合,先分布式再集群,具体实现就是业务拆分红不少子业务,而后针对每一个子业务进行集群部署,这样每一个子业务若是出了问题,整个系统彻底不会受影响。
另外,还有一个概念和分布式比较类似,那就是微服务。
微服务是一种架构风格,一个大型复杂软件应用由一个或多个微服务组成。系统中的各个微服务可被独立部署,各个微服务之间是松耦合的。每一个微服务仅关注于完成一件任务并很好地完成该任务。在全部状况下,每一个任务表明着一个小的业务能力。
区别:
1.分布式
将一个大的系统划分为多个业务模块,业务模块分别部署到不一样的机器上,各个业务模块之间经过接口进行数据交互。区别分布式的方式是根据不一样机器不一样业务。
上面:service A、B、C、D 分别是业务组件,经过API Geteway进行业务访问。
注:分布式须要作好事务管理。
分布式事务可参考:微服务架构的分布式事务解决方案
2.集群模式
集群模式是不一样服务器部署同一套服务对外访问,实现服务的负载均衡。区别集群的方式是根据部署多台服务器业务是否相同。
注:集群模式须要作好session共享,确保在不一样服务器切换的过程当中不会由于没有获取到session而停止退出服务。
通常配置Nginx*的负载容器实现:静态资源缓存、Session共享能够附带实现,Nginx支持5000个并发量。
3.分布式是否属于微服务?
答案是确定的。微服务的意思也就是将模块拆分红一个独立的服务单元经过接口来实现数据的交互。
4.微服务架构
微服务的设计是为了避免由于某个模块的升级和BUG影响现有的系统业务。微服务与分布式的细微差异是,微服务的应用不必定是分散在多个服务器上,他也能够是同一个服务器。
分布式和微服的架构很类似,只是部署的方式不同而已。