文章目录

  • 前言
  • 一、CAP原则
  • 二、BASE原则

前言

在分布式系统设计过程中,为了更加方便快捷的完成设计,推荐参考的设计原则。


提示:以下是本篇文章正文内容,下面案例可供参考

一、CAP原则

分布式系统有许多优点和缺点,其主要特点是一致性/可用性和分区容忍性。他们具体含义如下:

  • 一致性(Consistency):保持所有结点在同一时刻具有相同的/逻辑一致的数据。
  • 可用性(Availability):保证每个请求不管成功或者失败都有响应。
  • 分区容忍性(Partition Tolerance):系统中任何的信息丢失或者失败都不会影响系统的继续运作。


根据CAP原因,从图中可以看出分布式系统只能满足3种情况:

  • CA:满足一致性和可用性的系统。在扩展性上难有建树。
  • CP:满足一致性和分区容忍性的系统。通常性能不是特别高。
  • AP:满足可用性和分区容忍性的系统,通常对一致性要求低一些,但性能会比较高。

也就是说,任何的分布式系统都只能较好的完成其中两个指标,无法完成3个指标。微服务主要追求可用性和分区容忍性(AP),轻一致性(C)

二、BASE原则

在BASE理论中,一致性又分为强一致性和弱一致性(CAP原则中的一致性是指强一致性)。

  • 强一致性:当用户完成数据更新操作后,任何后续线程或者其他结点都能访问到最新的值。这样的设计是最友好的,即用户上一次的操作,下一次操作都能读到。但根据CAP原则,这种实现需要对性能做出较大的牺牲。
  • 弱一致性:当用户完成数据更新操作后,并不能保证后续线程或者其他结点马上访问到最新值,他只能通过某种方法保证最后的一致性。

BASE理论的核心思想是:即使分布式系统无法做到强一致性,也可以采用适当的方法达到最终一致性。

BASE原则:

  • BA(Basically Available 基本可用):在分布式系统中,最重要的需求是保证基本可用,有响应结果返回。
  • S(Soft State 软状态):其意义在于允许系统存在中间状态。一般来说,系统之间的数据通信都会有副本,而这些副本都会存在一定的延迟。这时推荐使用弱一致性代替强一致性。这样的好处在于,提高系统的可用性和性能。
  • E(Eventual Consistency 最终一致性):是指系统中的所有数据副本经过一定时间后,最终能够达到一致的状态,以保证数据的正确性。

BASE理论的应用场景时大型分布式系统,它核心内容是放弃强一致性,保证系统的可用性。因为分布式系统自身的融合和扩展就相当的复杂,如果需要保证强一致性就需要额外引入许多复杂的协议,这会导致技术的复杂化,同时对性能也有影响。BASE理论则建议让数据在一段时间内不一致,从而降低技术实现的复杂性,并提高系统的性能,最后通过某种手段使得数据达成最终一致即可。

一直在前进的路上,欢迎和感谢同路人的支持。

分布式系统的设计原则相关推荐

  1. 分布式系统架构设计原则和理论 --AKF 架构原则

    这 15 个架构原则来自<架构即未来 (The Art of Scalability)>[附录 2] 一书,作者马丁 L. 阿伯特和迈克尔 T. 费舍尔分别是 eBay 和 PayPal ...

  2. 分布式系统的构建原则

    什么是构建一个可维护和可扩展的系统的意义? 在早期,一个系统的形态,只是满足用户和服务器资源之间的通道,唯一要扩展和维护的是系统后面的资源,保证资源的可用和够用,而系统本身的压力并不大. 系统设计跟我 ...

  3. 架构师必须知道的架构设计原则

    目录 一.前言 二.软件设计原则 GRASP通用职责分配软件模式 1. 信息专家(Information Expert) 2. 创建者(Creator) 3. 低耦合(Low Coupling) 4. ...

  4. 分布式系统架构设计36式 – 第0式 - 设计总决

    动机 在"不易.简易.变易"这三个范畴里,技术是属于"变易"范畴的,其千变万化:"方法论"是属于"简易"范畴的,其具有领 ...

  5. 架构师必须掌握的架构设计原则

    如果一个架构或设计原则已经存在 15 年,例如单一职责和依赖倒置原则,我可以预期它还有 15 年甚至更久的生命期.原则是比具体技术更抽象,更接近事物本质,也更经得起时间考验的东西.这些原则沉淀在架构师 ...

  6. SOA 的基本概念及设计原则浅议

    SOA是英文词语"Service Oriented Architecture"的缩写,中文有多种翻译,如"面向服务的体系结构"."以服务为中心的体系结 ...

  7. 详细设计 存储分配_万字长文:云架构设计原则(一)

    译者序 AWS用户广泛,产品线复杂,AWS发布的白皮书<Architecting for the Cloud-AWS Best Practices>介绍了常见场景下云架构的最佳实践,不仅对 ...

  8. Erlang/OTP设计原则(文档翻译)

    http://erlang.org/doc/design_principles/des_princ.html 图和代码皆源自以上链接中Erlang官方文档,翻译时的版本为20.1. 这个设计原则,其实 ...

  9. API设计原则(觉得太合适,转发做记录)

    API设计原则 对于云计算系统,系统API实际上处于系统设计的统领地位,正如本文前面所说,K8s集 群系统每支持一项新功能,引入一项新技术,一定会新引入对应的API对象,支持对该 功能的管理操作,理解 ...

最新文章

  1. 第一次接触AgilePoint业务流程及任务管理(BPM)
  2. RunJar是什么进程?
  3. 对于Ping的过程,你真的了解吗?
  4. 万万没想到,JVM内存结构的面试题可以问的这么难?
  5. 分布式系统的唯一ID
  6. gson解析php,php,android_关于 Gson 解析JSON数据。。。,php,android - phpStudy
  7. jmeter--正则提取json串中一个大括号对象里指定字段值的的另一个字段的值
  8. 实现点击页面其他地方,隐藏div(vue)
  9. Shamir密钥分享算法 python实现
  10. windows挂载linux共享,永久挂载 Windows 共享
  11. MySQL中的事务隔离级别
  12. 富文本支持粘贴excel表格_Anki插件-OneNote importer(富文本批量导入)
  13. java中的getinstance_Java中的KeyPairGenerator getInstance()方法
  14. spring boot shiro视频
  15. 三、漏洞编号为CVE-2017-7494的复现(永恒之蓝)(Linux)(Ubuntu16.04.4)
  16. 200724 EXCEL
  17. 申宝股票-三大指数震荡下行
  18. MFC自制小游戏——躲避球(每日进度)
  19. npm ERR! code ELIFECYCLEnpm ERR! errno 1npm ERR! wlwl-dsfvue@1.0.0 dev: `node build/dev-server.js`报错
  20. 存储过程中的关键字--AS、GO的含义

热门文章

  1. [零刻]EQ12迷你主机设置来电开机自启教程
  2. Chrome启动页被360劫持
  3. Iframe嵌套拒绝接入
  4. docker php安装gd扩展_docker安装php扩展gd库
  5. 读取asserts 文件中的apk
  6. 开启工业新时代,OFweek 2019智能制造大会暨展览会圆满落幕!
  7. win10无法设置移动热点
  8. 一些关于计算机的小知识
  9. python 频繁项集_FP-Growth算法之频繁项集的挖掘(python)
  10. 关于超链接的一些总结