zoukankan      html  css  js  c++  java
  • 跟Brand学分布式

    https://www.cnblogs.com/wzh2010/p/15311142.html 原文链接

    我对分布式的理解最基础层面是在dubbo zookeeper , springcloud上的.
    但是出发点和引发我的思考的并不是这些微服务框架,
    而是基于mybatisplus中的版本号@Version.
    因为在mybatisplus之中有@Version注解用于解决多客户端修改同数据的事务问题,(但此时还没到分布式事务)
    使用这个注解可以得到解决,其原理之前的笔记或博客已经也记录过了.

    而分布式中的事务可能就牵扯道要用redis做一个version的处理了,毕竟可能牵扯到的表可能不在一个服务器中,
    但是又要进行同步操作.

    CA: 放弃分区容错性。非分布式架构,比如关系数据库,因为没有分区,但是在分布式系统下,CA组合就不建议了。
    
    AP: 放弃强一致性。追求最终一致性,类似的场景比如转账,可以接受两小时后到账,Eureka的注册也是类似的做法。 
    
    CP: 放弃可用性。zookeeper在leader宕机后,选举期间是不提供服务的。类似的场景比如支付完成之后出订单,必须一进一出都完成才行。 
    

    Brand这里说的CAP,即CAP理论.
    C:Consistency
    A:Avaliability
    P:Partition Tolerance

    这张图中实现CP的(一致性+分区容错性)的有MongoDB,HBase,Redis这种非关系型数据库
    实现AP理论(可用性,分区容错性)的有CouchDB,Cassandra,DynamoDB.
    实现CA理论(一致性+可用性)的有关系型数据库如SQL Server,MySQL,MariaDB(mysql的独享免费版).

    这种分布式的理论说明,在分布式条件下,没有绝对强一致或者高可用或容错性超强的设计,只能从三种模式中选其二.

    可以看到,对于分布式没有完美的解决方案,而只能从三中选二。就像你只能有一个老婆,而不能是变成我的前偶像王力宏,成为法外狂徒!(我恨他)

    当我在想,在看非Brand的博客了解分布式时,其中有二阶段提交,而在其中也提到了“协调者”,我不太清楚这个协调者具体的作用,
    是类似站岗的人员,指挥外来的外卖人员在指定地点送外卖,外来车辆依次停好车,外来人员预先进行登记这种事情吗?如果是,
    我就非常明白了,因为我也站岗过,对这种事情驾轻就熟。

    好,能看到图片的有福了,真实帅哥(想想其实也没我帅好吧感觉确实这个挺帅)。就想象他来指挥车辆和人员吧。

    再来一张别的,总之,这些帅哥,就是协调者。秩序维护协调者。

    而在分布式事务,例如二,或三阶段提交,都有一个预制的过程,并不能说,这个外卖员想进公司大楼就进,外来车辆想随便停车就能停,
    外来人员想进去找谁就找谁,That isn't right, so,make a plan,through the 2pc / 2pc let the transaction knowing who and what will give the database a update pouch.
    如上图,
    首先站岗人员对两个进入的车辆进行指挥,不能进行交叉停车,阻挡了道路(以至于后来的请求都堵住了)
    即执行了prepare阶段,站岗人员对着两个操作者说“每人一个车位,按先到者先停,进行停车”,之后两辆车则各自停好了。

    当然这个停车场,就属于一个数据库,没有分布式处理,即完全对应了@Version版本号到那一套。
    比如来了两辆车,站岗人员一看,就还有一个车位,则按优先到达处理原则(跟客户端先请求到处理一致)进行车位的安排停车,另一辆车,
    只好告诉他,车位已满(虽然你们也算是同一时间来的,但是按照队列处理后,*(毕竟不可能让汽车并驾齐驱地向停车位驶去,导致站岗人员不知道该指挥谁先停车(线程抢占阻塞))
    那怎么办呢,像大量的用户请求,不管是阿里的秒杀还是微信的红包,总会有一个先后顺序的,不管是令牌桶处理还是其它的处理方式,(那些之后更新-配合更新到消息队列学习),对吧,起码还是要有顺序的,不然就会出现超卖啊,余额为负的bug!~
    站岗人员还是要进行一辆车一辆车的指挥,毕竟在入口处,还是仅有车身宽度的地方驶入停车场的,如果两辆车能挤在一起通过,是不可能的,否则世界会变成二次元了。

    好,看完了小汽车,相信在注视着屏幕的你也明白了,先来后到的道理。(很多的丛林原则和社会原则也是基于此的)
    但是分布式的停车场(数据库)该怎样进行车辆(数据)的安排(更新)呢?

    假设刚才的停车位在大楼的左侧,而实际上在大楼的右侧还有一处停车的位置,两个停车的区域距离较远,一个区域的停车是内部员工用的,另一区域是外部人员拜访临时停车用的。(就假设Brand提到的订单数据看,库存数据库的售卖操作, 亦或是 何同学银行账户&野生钢铁侠同学银行账户的转账操作)
    那么当协调者(就是刚上传的那些帅哥)去进行不同人员车辆的安排时,这里写死一个场景,是说车辆都是一辆内部车辆+一辆外部车辆这么来的,
    那么每次协调者都将进行车辆的合理停车安排。处理完成后,数据将进行更新(内部人员+外部人员对公司的合理拜访业务完成),并更新同步到两个车位(库表)中。
    当然在这之前要进行登记等一些prepared操作,比如三阶段提交
    prepare ,pre-commit ,commit
    这里可以想象一下,内部销售人员带着外部人员来购买公司等软件。
    需要通过帅哥安排车位,并通过帅哥进行了登记(登记本)prepare,身份核实(通知单位是否有这个业务这两位人员)pre-commit,最终确认通过放行允许进行他们进入公司促成他们的软件销售业务commit。

  • 相关阅读:
    python
    Yii框架的学习指南(策码秀才篇)1-1 如何认识Yii framework
    yii执行流程简单介绍
    html5页面编码如何确定
    防止表单重复提交的几种策略
    2维数组排序
    YII框架开发一个项目的通用目录结构:
    phpcms添加图片投票
    windows下面apache配置虚拟目录(测试使用,发布网站不建议目录访问)
    js获取浏览器的版本代码
  • 原文地址:https://www.cnblogs.com/ukzq/p/15727674.html
Copyright © 2011-2022 走看看