什么是cap 理论 nacos 使用cp 或者ap 场景

CAP 理论是分布式系统设计中的一个基本原则,它指出在一个分布式系统中,一致性(Consistency)、可用性(Availability)和分区容错性(Partition Tolerance)这三个属性无法同时满足。

  • 一致性(Consistency):在分布式系统中,一致性是指数据在多个副本之间保持一致的特性。即当一个数据副本被更新后,其他副本也必须被相应地更新,以保证数据的一致性。

  • 可用性(Availability):可用性是指在分布式系统中,系统能够根据用户的请求正常响应并提供服务的能力。即系统需要时刻处于可用状态,能够处理用户的请求并返回正确的结果。

  • 分区容错性(Partition Tolerance):分区容错性是指在分布式系统中,系统能够容忍网络分区(节点之间无法直接通信)的发生,并能够继续工作。即系统能够通过网络将节点连接起来,即使某些节点无法与其他节点直接通信。

根据 CAP 理论,由于网络分区是不可避免的,因此在分布式系统设计中,必须在一致性和可用性之间做出权衡,从而选择满足分区容错性的方案。具体来说,在网络分区发生时,系统可以选择保证一致性(C)和分区容错性(P),即 CP 模型;或者选择保证可用性(A)和分区容错性(P),即 AP 模型。

Nacos 是一个开源的服务注册与发现、配置管理平台。在 Nacos 的设计中,支持了两种部署模式:

  • CP 模式:在 CP 模式下,Nacos 保证了数据的一致性(Consistency)和分区容错性(Partition Tolerance)。当网络出现分区故障时,Nacos 将暂停对外提供服务,以保证数据的一致性。CP 模式适用于对数据一致性要求较高、可用性可以暂时降低的场景。

  • AP 模式:在 AP 模式下,Nacos 保证了可用性(Availability)和分区容错性(Partition Tolerance)。即使在网络分区的情况下,Nacos 仍然可以继续对外提供服务,但此时可能会出现数据同步延迟或不一致的情况。AP 模式适用于对可用性要求较高、对数据一致性要求相对较低的场景。

CAP:  C: consistence  一致性。 A: 可靠性 applicability   : P: 分区容错性
   最多能同时满足两个条件,不能三个都满足. 目前的分布式要么是满足AP  要么是CP
   kafka:  AP :能用  速度要快
   rabbitMQ : cp  金融系统  电商系统强调数据一致
   nacos 还是cp or ap?   默认为AP。

但是在我们工作中,如果使用nacos,有些应用场景需要使用AP不能够满足我们的需求,这个时候就需要我们使用CP来进行实现, 具体可以进行切换: 
    切换:curl -X PUT "http://localhost:8848/nacos/v1/ns/operator/switches?entry=serverMode&value=CP"
          curl -X PUT "http://localhost:8848/nacos/v1/ns/operator/switches?entry=serverMode&value=AP"    
    选用何种模式
        一般来说,如果不需要存储服务级别的信息且服务实例是通过nacos-client注册,并能够保持心跳上报,那么就可以选择AP模。当前主流的服务如Spring cloud和 Dubbo服务,都适
    用于AP模式。AP模式为了服务的可能性而减弱了一致性,因此AP模式下只支持注册临时实例。
    如果需要在服务级别编辑或者存储配置信息,那么CP是必须,K8S服务和DNS服务则适用于CP模式。CP模式下则支持注册持久化实例,此时则是以Raft 协议为集群运行模式,该模式下注册实例之前必须先注册服务,如果服务不存在,则会返回错误。    

具体应用场景如下:

  1. 金融系统:在金融交易系统中,数据的一致性至关重要,因为任何错误都可能导致严重的后果。因此,通常会优先选择一致性和分区容忍性,并愿意牺牲一定的可用性。

  2. 社交网络:在社交网络中,用户数量庞大,高可用性是非常重要的,因为用户希望能随时随地访问社交平台。因此,通常会优先选择可用性和分区容忍性,并愿意在一定情况下牺牲一致性。

  3. 物联网系统:在物联网系统中,设备数量巨大,而且网络环境可能不太稳定,分区容忍性是非常重要的特性。同时,对于某些实时监控数据,可用性也是至关重要的。因此,通常会优先选择可用性和分区容忍性,并愿意在一定情况下牺牲一致性。

  4. 在云计算平台中,由于网络、设备、服务等因素的不确定性,分区容忍性和可用性是非常重要的。因此,云计算平台通常会优先考虑这两个特性,并在必要时牺牲一致性。

在实际的分布式系统设计中,根据不同的业务需求和系统场景,可以根据CAP原则进行权衡和取舍,选择最适合的特性组合。

 

根据具体的业务需求,您可以选择使用 Nacos 的 CP 模式或 AP 模式来满足您的系统设计和可用性要求。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值