本文由黑壳博客转载

本文来源[转]大家都在说的分布式系统到底是什么?

壳叔搞笑时间

在外地出差,下火车后住的便宜宾馆,68块钱一天的那种,两个晚上了,不停的被客房服务骚扰,每晚都要两三次敲门,烦不胜烦,要不是交了四天的钱,我绝对早早搬走。睡得正香呢,一会儿一敲的烦不烦。要在我年轻时候也就罢了,关键我都快26了……

正文

随着大型网站的各种高并发访问、海量数据处理等场景越来越多,如何实现网站的高可用、易伸缩、可扩展、安全等目标就显得越来越重要。为了解决这样一系列问题,大型网站的架构也在不断发展。提高大型网站的高可用架构,不得不提的就是分布式。本文主要简单介绍了分布式系统的概念、分布式系统的特点、常用的分布式方案以及分布式和集群的区别等。

一、集中式系统

在学习分布式之前,先了解一下与之相对应的集中式系统是什么样的。

集中式系统用一句话概括就是:一个主机带多个终端。终端没有数据处理能力,仅负责数据的录入和输出。而运算、存储等全部在主机上进行。现在的银行系统,大部分都是这种集中式的系统,此外,在大型企业、科研单位、军队、政府等也有分布。集中式系统,主要流行于上个世纪。

集中式系统的最大的特点就是部署结构非常简单,底层一般采用从IBM、HP等厂商购买到的昂贵的大型主机。因此无需考虑如何对服务进行多节点的部署,也就不用考虑各节点之间的分布式协作问题。但是,由于采用单机部署。很可能带来系统大而复杂、难于维护、发生单点故障(单个点发生故障的时候会波及到整个系统或者网络,从而导致整个系统或者网络的瘫痪)、扩展性差等问题。

二、分布式系统(distributed system)

在《分布式系统概念与设计》一书中,对分布式系统做了如下定义:

分布式系统是一个硬件或软件组件分布在不同的网络计算机上,彼此之间仅仅通过消息传递进行通信和协调的系统

简单来说就是一群独立计算机集合共同对外提供服务,但是对于系统的用户来说,就像是一台计算机在提供服务一样。分布式意味着可以采用更多的普通计算机(相对于昂贵的大型机)组成分布式集群对外提供服务。计算机越多,CPU、内存、存储资源等也就越多,能够处理的并发访问量也就越大。

从分布式系统的概念中我们知道,各个主机之间通信和协调主要通过网络进行,所以,分布式系统中的计算机在空间上几乎没有任何限制,这些计算机可能被放在不同的机柜上,也可能被部署在不同的机房中,还可能在不同的城市中,对于大型的网站甚至可能分布在不同的国家和地区。但是,无论空间上如何分布,一个标准的分布式系统应该具有以下几个主要特征:

分布性

分布式系统中的多台计算机之间在空间位置上可以随意分布,系统中的多台计算机之间没有主、从之分,即没有控制整个系统的主机,也没有受控的从机。

透明性

系统资源被所有计算机共享。每台计算机的用户不仅可以使用本机的资源,还可以使用本分布式系统中其他计算机的资源(包括CPU、文件、打印机等)。

同一性

系统中的若干台计算机可以互相协作来完成一个共同的任务,或者说一个程序可以分布在几台计算机上并行地运行。

通信性

系统中任意两台计算机都可以通过通信来交换信息。

和集中式系统相比,分布式系统的性价比更高、处理能力更强、可靠性更高、也有很好的扩展性。但是,分布式在解决了网站的高并发问题的同时也带来了一些其他问题。首先,分布式的必要条件就是网络,这可能对性能甚至服务能力造成一定的影响。其次,一个集群中的服务器数量越多,服务器宕机的概率也就越大。另外,由于服务在集群中分布是部署,用户的请求只会落到其中一台机器上,所以,一旦处理不好就很容易产生数据一致性问题。

常用的分布式方案

分布式应用和服务

将应用和服务进行分层和分割,然后将应用和服务模块进行分布式部署。这样做不仅可以提高并发访问能力、减少数据库连接和资源消耗,还能使不同应用复用共同的服务,使业务易于扩展。

分布式静态资源

对网站的静态资源如JS、CSS、图片等资源进行分布式部署可以减轻应用服务器的负载压力,提高访问速度。

分布式数据和存储

大型网站常常需要处理海量数据,单台计算机往往无法提供足够的内存空间,可以对这些数据进行分布式存储。

分布式计算

随着计算技术的发展,有些应用需要非常巨大的计算能力才能完成,如果采用集中式计算,需要耗费相当长的时间来完成。分布式计算将该应用分解成许多小的部分,分配给多台计算机进行处理。这样可以节约整体计算时间,大大提高计算效率。

分布式与集群

分布式(distributed)是指在多台不同的服务器中部署不同的服务模块,通过远程调用协同工作,对外提供服务。

集群(cluster)是指在多台不同的服务器中部署相同应用或服务模块,构成一个集群,通过负载均衡设备对外提供服务。

关于我们

程序员太辛苦了

请善待你们身边的每一位程序员~

欢迎在评论写下你的程序员趣事,程序员不是一个死板的职业~~

以上内容,均来自互联网~

欢迎扫描二维码加入我们的小组织 ,大家都叫壳叔,期待你的到来。
黑壳网交流群 Q群:200408242

大家都在说的分布式系统到底是什么?相关推荐

  1. 大家都在说的分布式系统到底是什么

    转载自 大家都在说的分布式系统到底是什么 随着大型网站的各种高并发访问.海量数据处理等场景越来越多,如何实现网站的高可用.易伸缩.可扩展.安全等目标就显得越来越重要.为了解决这样一系列问题,大型网站的 ...

  2. 量子物理 詹班 计算机,连爱因斯坦都被困其中,量子力学到底有多厉害?

    原标题:连爱因斯坦都被困其中,量子力学到底有多厉害? 量子力学有多可怕?连爱因斯坦都被困其中,正常人要是能弄懂它,改变命运只在分秒之间. 爱因斯坦70岁生日时,收到了一份非常独特的生日礼物,共有25位 ...

  3. 云服务器和虚拟主机和VPS都是什么意思?到底有啥区别呢?

    我们公司最近打算上线部署一款客户管理系统需要租一个服务器.结果在选购时,还是纠结了好久,不知道要买云服务器还是虚拟主机.更搞不清楚云服务器,虚拟主机,VPS都是什么意思,到底之间有啥区别呢? 最后查了 ...

  4. 都在说DeFi,到底什么是DeFi?

    来源 | 巴比特资讯 封图 | CSDN 下载自视觉中国 Defi的崛起 几年前区块链行业还没有Defi这个概念,从默默无闻的"穷小子",一跃成为区块链行业的"扛霸子&q ...

  5. 米家的扫地机器人是灰色_都做扫地机器人,到底谁更胜一筹?科沃斯VS米家、石头...

    [极度网-科技犬上手体验] 有了扫地机器人,是否就不用动手扫地了? 扫地机器人对房间边角的清洁能力如何? 在无人情况下机器人清扫真的安全吗? 另外,机器人工作时的噪音大小.操控方式.清扫路径规划等又怎 ...

  6. 大家平时天天说的分布式系统到底是什么东西?

    目录 1.从单块系统说起 2.团队越来越大,业务越来越复杂 3.分布式出现:庞大系统分而治之 4.分布式系统所带来的技术问题 5.一句话总结:什么是分布式系统设计和开发经验 6.补充说明:中间件系统及 ...

  7. 那xxx.class.getName()為什麼能這樣寫?? 看了半天都快搞不清楚到底在程式中的example到底是class ? object ? 還是instance了

    bunny wrote: 這就是為什麼 Java 需要去定義寫作規範的問題了 一般來說, Java 會建議你 Class 的名稱, 首字要大寫 而該 Class 的實體, 就是 instance 可以 ...

  8. python都学什么啊-Python到底有什么用?为什么那么多人都在学Python?

    现如今无论是工作汇报.产品设计.后台设计甚至是数据大屏,越来越多的行业都离不开与数据打交道! Excel作为数据必备工具,一直以来,在求职中有着不可动摇的地位! 随着互联网的发展,每个企业都开始涉足大 ...

  9. 阿里、京东都在说的赋能到底是什么?

    谷歌创始人之一拉里·佩奇说,未来组织中最重要的功能已经越来越清晰,那就是赋能,而不再是管理或激励. 赋能是最近几年比较火的词,阿里说要赋能商家,京东到家发布了"零售赋能"新战略,联 ...

最新文章

  1. jquery_3month
  2. python黑色背景编辑器_如何更换python默认编辑器的背景色
  3. php验证旧密码,PHP验证数据库密码问题
  4. 实现 OutOfMemory​
  5. 怎么样才能玩转前端所有的CSS背景相关问题?
  6. Ubuntu搭建联盟链,实现节点之间数据同步
  7. 用matlab画图的好处,用matlab画图注意事项
  8. php类最大多少行合适,计算最大包大小(PHP)
  9. 如何收割流量红利?UB Store的直播电商“三宝”
  10. AIDL解析(一):AIDL原理解析
  11. Redis持久化——AOF机制详解
  12. SQLyog 报错2058 :连接 mysql 8.0.11 解决方法
  13. [ecshop 资料] ecshop 安装须知 - 支付插件的问题 。。ectouch 小京东
  14. 数据资产管理的5个步骤和6个要素
  15. 直接插入排序顺序结构
  16. 超级计算机排行榜历年,历代游戏主机浮点运算能力排行榜 究竟谁才是真正的性能怪兽...
  17. 大数据开发的前景和就业如何?该如何去学习它?
  18. 手机怎么压缩照片?手机压缩照片方法分享
  19. 微信群很多怎么管理?针对这个问题,今天教你几招。
  20. 图腾标准服务器机柜型号,图腾常用的机柜型号及全参数

热门文章

  1. 向下兼容性格什么意思_担心对方只是向下兼容,并不是从心底里接纳我怎么办?...
  2. 若依ajax返回数据,Ajax
  3. 传播Virus.Win32.AutoRun.f/Worm.Win32.Delf.b的网页
  4. js获取剪切板内容(企业微信内嵌网页)
  5. 目标检测算法——医学图像开源数据集汇总(附下载链接)
  6. 联想R7000 Ubuntu解决触摸板失灵
  7. AOP @AfterReturning的使用
  8. 浏览器开发者工具用法
  9. 百度AI(一) | 人脸对比
  10. 来自某位小萌新的Web安全学习--day1