简单聊聊分布式和集群

前言

分布式和集群,我们都听的比较多,分布式系统和集群的概念对于刚进入职场的小伙伴可能不是很清楚,这篇文章我们就一起看看两者到底是什么,有什么区别。

什么是分布式系统?

先看下书面解释:
分布式系统(Distributed System)是由多个相互独立的计算节点组成的系统,这些节点通过网络相互通信与协作,以实现共同的目标。分布式系统的设计思想是将计算任务分散到不同的节点上,每个节点负责特定的子任务,从而提高系统的整体性能、可靠性和可扩展性。

书面解释看完了也就看完了,我还是比较喜欢大白话,那我们就大白话来解释一下:
假设我们有一个电商系统,早期时候我们将它部署到一台服务器上,如下图所示:
在这里插入图片描述
这个系统运行在一个服务器节点上,里面包含订单(order)服务、用户(user)服务、商品(item)服务。
这种情况下存在什么问题呢? 就是所有的计算和任务都依赖于单个节点(理解为部署的这台服务器)的性能,那一台服务器的处理能力肯定是有上限的,一旦达到上限,系统的整体性能就会受到限制,难以进一步扩展,而且扩展很麻烦。同时,如果这台服务器宕机,那么整个系统将不能使用。也就是我们说的单点故障。还有其他问题,我就不一一举例了。

那怎么解决呢?
现在,我们将系统拆分成各个子系统;这时电商系统就被拆分为:订单(order)子系统、用户(user)子系统、商品(item)子系统,他们共同协作完成电商系统的完整服务,如下图:
在这里插入图片描述
每个子系统部署在独立的服务器上,他们共同协作以提供完整功能服务。
通过以上介绍,总结出以下特点:

  • 独立性:每个节点都是独立的计算单元,拥有自己的处理器、内存和存储
  • 通信:节点之间通过网络通信进行数据交换和协作
  • 分布性:任务和数据分散在不同节点上进行处理
  • 容错性:系统能容忍部分节点的故障,通过冗余和数据副本保证系统的可靠性
  • 可扩展性:通过增加更多的节点,系统可以轻松扩展处理能力

接下来,我们看看集群的概念

什么是集群?
集群(Cluster)是由多台计算机通过高速网络连接构成的一个整体系统,这些计算机共同工作以提供高性能、高可用性的服务。集群系统的设计思想是通过将多个计算机资源整合起来,共同完成任务,从而实现负载均衡、故障转移和高可用性。
大白话说就是,把一个完整的系统复制多份,部署在不同的节点(服务器)上,如下图所示:

在这里插入图片描述
每一个节点上,都是完整的系统,能提供完整的服务。这个就是集群啦。
特点如下:

  • 高可用性:通过冗余配置和故障转移机制,保证系统的连续运行。
  • 高性能:通过并行处理,提高系统的整体性能。
  • 负载均衡:将任务均匀分配到各个节点上,避免单点过载。
  • 集中管理:通常通过集群管理软件统一管理各个节点。

那二者有什么区别?
往下看:

分布式系统与集群的区别

设计目标:

  • 分布式系统:侧重于任务和数据的分散处理,提高系统的扩展性和容错性。
  • 集群:侧重于高可用性和高性能,通过节点协同工作实现负载均衡和故障转移。

节点关系:

  • 分布式系统:节点相对独立,具有更高的自治性和独立性。
  • 集群:节点紧密耦合,通过统一的集群管理软件进行协调和管理。

应用场景:

  • **分布式系统:**适用于需要大规模数据处理和存储的场景,如分布式数据库和文件系统。
    **集群:**适用于需要高性能计算和高可用服务的场景,如科学计算和服务器集群。

总结

分布式系统和集群都是通过多个节点协同工作来提高系统性能和可靠性的技术,但它们在设计目标、节点关系和应用场景上有所不同。分布式系统侧重于任务和数据的分散处理,而集群侧重于通过节点协同工作实现高可用性和高性能。在实际应用中,常常需要根据具体需求选择合适的架构,以充分发挥系统的优势。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/631036.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

学习笔记-C++

目录 1、何为常量 2、关键字 3、实型 4、水平制表符 5、string字符串 6、C中的三目运算符 7、随机数种子 8、结构体 9、各的区 10、引用 11、函数默认参数 12、函数占位参数 13、函数重载 14、私有属性 15、让另一个类作为本类的成员 16、声明和实现的文件…

正点原子[第二期]Linux之ARM(MX6U)裸机篇学习笔记-15.7讲 GPIO中断实验-编写按键中断驱动

前言: 本文是根据哔哩哔哩网站上“正点原子[第二期]Linux之ARM(MX6U)裸机篇”视频的学习笔记,在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。…

初识Django

day15 初识Django Python知识点:函数、面向对象。前端开发:HTML、CSS、JavaScript、jQuery、BootStrap。MySQL数据库。 Python的Web框架: Flask,自身短小精悍 第三方组件。Django,内部已集成了很多组件 第三方组件。…

GM812条码模块的产品说明

1 模块尺寸 引脚定义 (单位:mm) 接口定义:规格 1.25*6Pin 接口说明: a) UART 缺省波特率为 9600bps,数据格式:8 位数据位,1 位停止位,无校验位。 b) 如果上位机是 MCU(3.3V&#x…

Java面试八股之Java中有哪些原子类,原理是什么

Java中有哪些原子类,原理是什么 AtomicInteger 和 AtomicLong: 用于对整数(int)和长整数(long)进行原子操作。 原理:它们内部封装了一个整型或长整型变量,并通过使用Unsafe类提供…

括号生成[中等]

优质博文:IT-BLOG-CN 一、题目 数字n代表生成括号的对数,请你设计一个函数,用于能够生成所有可能的并且 有效的 括号组合。 示例 1: 输入:n 3 输出:["((()))","(()())","(())(…

项目管理-案例重点知识(干系人管理)

项目管理:每天进步一点点~ 活到老,学到老 ヾ(◍∇◍)ノ゙ 何时学习都不晚,加油 四、干系人管理 案例重点知识 干系人管理 案例 重点内容: (1)权力利益方格、权力影响方格&#xff…

GPT-4o“成精了”:推测技术原理,附送“美国湾区”小道消息

原创:谭婧 如果你能跟上技术发展,那大多数技术提升都是按部就班, 偶而会有突破性进展。 如果你仅仅吃瓜,那OpenAI的所有新闻, 你都可以写成: “改写历史”“干翻所有”“颠覆世界”。 真的颠覆世界了吗&…

ue引擎游戏开发笔记(41)——行为树的建立(2)--丰富ai行为:巡逻后返回原处

1.需求分析: 就敌人ai而言,追踪到敌人有可能丢失目标,丢失目标后应该能返回原来位置,实现这一功能。 2.操作实现: 1.思路:利用clear value函数,禁用掉当前的追踪功能,执行之后的返…

Git项目管理——提交项目和版本回退(二)

个人名片: 🎓作者简介:嵌入式领域优质创作者🌐个人主页:妄北y 📞个人QQ:2061314755 💌个人邮箱:[mailto:2061314755qq.com] 📱个人微信:Vir2025WB…

SSL证书对于网络安全的重要作用

SSL证书是一种数字证书,它通过加密技术确保了客户端(如浏览器)与服务器之间的数据传输安全。当一个网站安装了SSL证书后,用户在浏览器地址栏中可以观察到HTTPS(超文本传输安全协议)前缀和挂锁图标&#xff…

聚鼎科技:装饰画行业到底怎么样

在当代社会,随着人们审美水平的提升和生活品质的追求,装饰画行业呈现出蓬勃的发展态势。这一行业不仅关系到文化艺术的传承与创新,也与市场经济紧密相连,其前景值得深入探讨。 装饰画行业的市场潜力巨大,它贯穿于家居装…

Git使用(4):分支管理

一、新建分支 首先选择Git -> Branches... 然后选择 New Branch,输入新分支名称,例如dev。 可以看到右下角显示已经切换到新建的dev分支了。 push到远程仓库,可以看到新添加的分支。 二、切换分支与合并分支 为了演示合并分支&#xff0c…

【opencv】答题卡判分实验

实验环境: anaconda、jupyter notebook 实验用的包:numpy、matplotlib、opencv 实验的目的还是以熟悉图像的透视变换、轮廓特征提取为主要目的 关于如何判断答题卡被选项:通过几个覆盖备选项的掩膜与原二值图像想与,最终整个图像…

Python100个库分享第23个—wordcloud(词云图)

目录 专栏导读库的介绍库的安装基础使用1:将TXT文本转为词云图基础使用2:使用自定义字体和形状基础使用3:中文词云图停用词(中英文版)-代码是中文版总结 专栏导读 🌸 欢迎来到Python办公自动化专栏—Python处理办公问题&#xff0…

JavaWeb--18 tlias-web-management 登录认证

登录认证 1 登录功能功能开发 2 登录校验2.1 问题分析2.2 会话技术CookieSession令牌技术 2.3 JWT令牌介绍生成和校验登录下发令牌 2.4 过滤器Filter拦截路径过滤器链 登录校验-Filter 2.5 拦截器InterceptorInterceptor详解执行流程 登录校验- Interceptor 3 异常处理3.1 当前…

文本分类TextRCNN模型(pytorch实现)

文本分类TextRCNN模型 RCNN简介TextRCNN模型介绍TextRCNN代码(文本10分类) RCNN简介 从之前的文章中介绍过RNN的优点是能够捕捉到序列的时序信息,这可能有利于捕获长文本的语义。但是RNN对于文本序列后面的单词获取到的语义会更多&#xff0…

Python 全栈体系【四阶】(四十五)

第五章 深度学习 十、生成对抗网络(GAN) 1. 图像生成技术概述 1.1 什么是图像生成技术 图像生成技术是指利用机器学习或深度学习等人工智能技术,通过训练模型来生成逼真的图像。这些技术可以根据给定的输入,生成与真实图像相似…

线性系统(二)

线性系统(二) 1.直观理解线性方程组结构2. 不同解的结论3. 更一般的高斯-约旦消元法4.齐次线性方程组 链接: 线性系统(一) 1.直观理解线性方程组结构 长这样,方程就有解,即相交坐标。 长这样,…

《天空之城》观后感

曾经很长一段时间都着迷于《天空之城》这段旋律,一遍一遍不厌其烦地听,静谧而温馨、豪迈却苍凉,各种复杂的感受随着起伏的音符流淌进心里。多年之后才知道这首曲子出自宫崎骏的同名动画电影。说来也有意思,似乎大多数人是通过电影…