V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Powered
V2EX  ›  程序员

分布式 CAP 理论的一个问题请教

  •  
  •   Powered · 2017-02-22 17:57:23 +08:00 · 2123 次点击
    这是一个创建于 2829 天前的主题,其中的信息可能已经有所发展或是发生改变。

    摘自博客:

    在某时候如果满足 AP ,分割的节点同时对外服务但不能互相通信,将不能满足 C (即状态不一致)

    为什么分割的节点同时对外服务但不能互相通信?求解

    6 条回复    2017-02-23 13:37:20 +08:00
    JhZ7z587cYROBgVQ
        1
    JhZ7z587cYROBgVQ  
       2017-02-22 18:05:39 +08:00
    应该是指因为节点分割带来的数据同步延时导致的一致性不满足吧?
    Powered
        2
    Powered  
    OP
       2017-02-22 18:35:47 +08:00
    @jason0916 所以要同时满足 CA ,就能出现网络分区是吗
    Powered
        3
    Powered  
    OP
       2017-02-22 18:36:19 +08:00
    @jason0916 #2 “就”和“能”之间添加“不”
    JhZ7z587cYROBgVQ
        4
    JhZ7z587cYROBgVQ  
       2017-02-22 18:51:11 +08:00
    @Powered 按照 cap 理论来说是这样的
    jybox
        5
    jybox  
       2017-02-22 18:58:10 +08:00
    可以设想一下,假设出现了分区( P ),就是你的服务器被分成了两个部分,每个部分内部可以通讯,也都可以分别对外服务,但两个部分之间不能通讯。这个时候你就必须做出一个选择:

    1. 要么保证可用性( A ),继续允许读写操作,但因为两个部分无法同步数据,所以会出现不同步( C )
    2. 或者保证一致性( C ),拒绝写入操作,直到两个部分恢复再允许写入,但这样就会出现服务不可用( A )

    或者如果你可用性和一致性都需要的话,那你就无法满足分区容错性。
    Mirana
        6
    Mirana  
       2017-02-23 13:37:20 +08:00
    网络分区
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1192 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 18:05 · PVG 02:05 · LAX 10:05 · JFK 13:05
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.