什么是集群(常见的分布式系统)
对于集群、分布式和微服务,大家在工作中可能经常会听到,但是如果问你它们之间存在什么样的区别和联系,可能你一下子又感觉说不清楚,今天就这个话题,趁着周末时间,跟大家来一起聊聊。弄明白是什么
要做三者之间的对比,首先要弄明白它们分别是什么?集群
集群是指将多台服务器集中在一起,每台服务器都实现相同的业务,做相同的事情。
但是每台服务器并不是缺一不可,存在的作用主要是缓解并发压力和单点故障转移问题。我们可以利用一些廉价的符合工业标准的硬件构造高扩展、高性能、低成本、高可用的系统。
集群主要具有以下特性:伸缩性(Scalability):一组服务器组在一起,像单个服务器一样分担处理一个繁重的任务,我们只需要将新的服务器加入集群中即可;高可用性(Highavailability):集群的出现就是为了使集群的整体服务尽可能可用,以便考虑计算硬件和软件的易错性,避免单点失效发生;负载均衡(Loadbalancing):均衡的应用程序处理负载或网络流量负载,使负载可以在计算机集群中尽可能平均地分摊处理。高性能(HighPerformance):并行计算(或称平行计算)是相对于串行计算来说的,并行计算能力的目的是用来提高计算速度。
分布式
分布式服务是指将多台服务器集中在一起,服务是分散部署在不同的机器上的。
每台服务器都实现总体中的不同业务,做不同的事情。一个服务可能负责几个功能,是一种面向SOA的架构。各分开部署的部分彼此通过各种通讯协议交互信息,并且每台服务器都缺一不可,如果某台服务器故障,则部分功能缺失,或导致整体无法运行。
分布式存在的主要作用是大幅度的提高效率,缓解服务器的访问和存储压力。区别分布式的方式是一个业务分拆多个子业务,部署在不同的服务器上。
例如将一个大的系统划分为多个业务模块,业务模块分别部署到不同的机器上,各个业务模块之间通过接口进行数据交互。
微服务
微服务就是很小的服务,小到一个服务只对应一个单一的功能。
每个微服务仅于完成一件任务并很好地完成该任务,这个服务可以单独部署运行。各个微服务之间是松耦合的,服务之间可以通过RPC来相互交互。每个微服务都是由独立的小团队开发、测试、部署,上线,负责它的整个生命周期。
在做架构设计时,当你估算过最大用户量和并发量后,计算出单个应用服务器能否满足需求。如果用户量只有几百人的小应用,单体应用就能搞定,即所有应用部署在一个应用服务器里。如果是很大用户量,且某些功能会被频繁访问,或者某些功能计算量很大,建议将应用拆解为多个子系统,各自负责各自功能,这就是微服务架构。
弄清楚异同点
弄明白是什么之后,就可以尝试找找它们之间的异同点了。集群与分布式
区别1:部署多台服务器的业务是否相同。
集群模式:不同服务器部署同一套服务对外访问,实现服务的负载均衡;
分布式:其中每一个节点,都可以做集群,而集群并不一定就是分布式的。
比如站点访问的人多了,可以做一个群集。前面放一个响应服务器,后面几台响应服务器完成同一业务。如果有业务访问的时候,响应服务器看哪台服务器的负载不是很重,就将任务调度给哪一台去完成。
而分布式,从窄意上理解也跟集群差不多。但是它的组织比较松散,不像集群有一个组织性,一台服务器垮了,其它的服务器可以顶上来。分布式的每一个节点都完成不同的业务,一个节点垮了那这个业务就不可访问了。
注:集群模式需要做好Session共享,确保在不同服务器切换的过程中不会因为没有获取到Session而引起服务终止。
区别2:提升效率的方式不同。
分布式:以缩短单个任务的执行时间来提升效率的;
集群:通过提高单位时间内执行的任务数来提升效率。
例如:如果一个任务由10个子任务组成,每个子任务单独执行需1小时,则在一台服务器上执行该任务需10小时。采用分布式方案,提供10台服务器,每台服务器只负责处理一个子任务,不考虑子任务间的依赖关系,执行完这个任务只需一个小时。采用集群方案,同样提供10台服务器,每台服务器都能独立处理这个任务。假设有10个任务同时到达,10个服务器将同时工作,经过10小时后,10个任务执行完成。这样整体来看,还是1小时内完成一个任务。
注:分布式需要做好事务管理。分布式与微服务
区别点:架构很相似,只是部署的方式不一样而已。
微服务是一种架构风格,一个大型复杂软件应用由一个或多个微服务组成。系统中的各个微服务可被独立部署,各个微服务之间是松耦合的。每个微服务仅于完成一件任务并很好地完成该任务。在所有情况下,每个任务代表着一个小的业务能力。微服务的应用不一定是分散在多个服务器上,它也可以是同一个服务器。
微服务相比分布式服务来说,它的粒度更小,服务之间耦合度更低。由于每个微服务都由独立的小团队负责,因此它敏捷性更高。分布式服务最后都会向微服务架构演化,这是一种趋势。不过服务微服务化后带来的挑战也是显而易见的,例如服务粒度小,数量大,后期运维难度会增大。分布式是否属于微服务?
答案是肯定的。
微服务将模块拆分成一个独立的服务单元通过接口来实现数据的交互。生产环境下的微服务肯定是分布式部署的,分布式部署的应用不一定是微服务架构的。总结
1、集群
复制部署,能力一致,目的是实现:伸缩性、高可用、负载均衡和高性能;
2、微服务
分散能力,将大型复杂的软件拆分为多个微服务组成(不一定分散在多个服务器,可以是同一个服务器);
3、分布式
分散部署,是一种面向SOA的架构,服务分散部署在不同的机器上,实现不同业务,做不同的事情。
END
作者:架构精进之路,专注软件架构研究,技术学习与个人成长,并私信我回复01,送你一份程序员成长进阶大礼包,欢迎勾搭。
技术架构精进专注架构研究,技术分享
Thanksforreading!
龙飞虎股票(股票技术指标大全详解)龙飞虎股票(股票技术指标大全详解)龙飞虎,又名克拉美书,苏南暨阳人士,为人低调,谦和,谨慎,富有爱心,有强烈的责任心,入市多年,2009年开始全职之路,通过股市实现财务自由。股灾账
配置好的笔记本电脑(最高配的笔记本电脑)配置好的笔记本电脑(最高配的笔记本电脑)有人问我现在到底是买笔记本电脑好还是买平板电脑好?又不玩大型网游,主要是学习和办公需求为主,买平板电脑又感觉性能单一了,买笔记本电脑又感觉笨
电脑维修教程(电脑维修方法与技巧)电脑维修教程(电脑维修方法与技巧)电脑其实很好修的,不是装系统就是换配件,不过各种配件你都要齐全。一询问查看故障现象接到一台主机,首先要知道故障现象,然后才能对症下药。比如询问客人
计算机故障(电脑常见的10种故障)计算机故障(电脑常见的10种故障)1。故障现象一台主机,每次开机时BIOS的参数必须重设,才能进入系统。进入系统后一切正常,关机重新启动后,BIOS的值丢失。但热启动没这种现象。分
今日岷县当归价格多少(甘肃岷县全当归)年8月20日岷县中药材市场快讯,年4月12日岷县中药材市场快讯,当归头切片,且上市量大,当归当归饮片走缓党参交易走快。野生当归很少很少,上货量有所增加当归成品水洗。党参人气旺。但交
购买笔记本注意事项(2021选购笔记本电脑须知)购买笔记本注意事项(2021选购笔记本电脑须知)本人年轻时因为各种套路而迷迷糊糊地买到了坑机,所以希望有意愿选购笔记本的同学在阅读我的文章后对电脑有一定了解。首先是电脑配置的一些基
怎么全选文件(文件如何快速全选)电脑要快速的办公需要认识快捷键的方式,知道如何用电脑的快捷键让网友们可以每天学习电脑的小知识的技巧,下面小编给大家介绍一下电脑全选的快捷键,希望对大家有帮助。1。按ctrla。可以
微信聊天记录批量全选(微信聊天记录怎么全选发送)作为日常大众使用最多的聊天沟通软件,其聊天记录是属于个人隐私内容,并且删除后一般很难找回。企业使用进行和客户沟通时除了聊天记录不能监控到外还不能防止成员随意删除重要信息。但是在企业
微信聊天记录如何全选(微信好友删除了怎么找回来)被问了太多次聊天记录恢复,今天将大部分场景都覆盖,给大家来个超全超细的聊天记录恢复聊天记录方法。一官方推荐恢复聊天记录方法1自带recover方法当你的遇到突然的崩溃等大型bug,
在线教育直播软件(免费直播教学平台)在线教育直播软件(免费直播教学平台)现在的直播平台如果是免费直播,平台的不稳定卡顿以及安装使用的不便利,无疑将导致用户体验非常不好,冥冥之中起到了反宣传的效果。如果是收费直播课程,
哪里学唱歌(成人学声乐去哪里学)用心的言果,轻奢学唱歌丨Sing吧广州学唱歌培训您与专业歌手的唱功之间,还缺一个Sing吧!唱歌不好听,是多么令人沮丧与束手无策想不想做KTV的麦霸?只要一唱歌,大家就觉得超级惊艳