news 2026/4/23 10:44:40

分布式系统入门:CAP 理论与一致性算法详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
分布式系统入门:CAP 理论与一致性算法详解

CAP 理论核心概念

CAP 理论指出分布式系统最多只能同时满足一致性(Consistency)、可用性(Availability)、分区容错性(Partition Tolerance)中的两项。

  • 一致性 (C):所有节点访问同一份最新数据。
  • 可用性 (A):非故障节点在合理时间内返回响应。
  • 分区容错性 (P):网络分区时系统仍能运作。

一致性算法实现(Paxos 简化版)

以下代码模拟 Paxos 算法的提案阶段,使用 Python 实现基础逻辑:

class PaxosNode: def __init__(self, node_id): self.node_id = node_id self.proposed_value = None self.accepted_value = None self.promised_proposal_id = 0 def prepare(self, proposal_id): if proposal_id > self.promised_proposal_id: self.promised_proposal_id = proposal_id return {"status": "promised", "accepted_value": self.accepted_value} return {"status": "rejected"} def accept(self, proposal_id, value): if proposal_id >= self.promised_proposal_id: self.accepted_value = value self.promised_proposal_id = proposal_id return {"status": "accepted"} return {"status": "rejected"} # 模拟三个节点的集群 nodes = [PaxosNode(i) for i in range(3)] # 提案阶段 proposal_id = 10 value = "data_v1" for node in nodes: response = node.prepare(proposal_id) print(f"Node {node.node_id} prepare response: {response}") # 接受阶段(仅半数以上节点响应时) if sum(1 for node in nodes if node.prepare(proposal_id)["status"] == "promised") > len(nodes)/2: for node in nodes: response = node.accept(proposal_id, value) print(f"Node {node.node_id} accept response: {response}")

https://www.zhihu.com/zvideo/1993908941005035175/
https://www.zhihu.com/zvideo/1993908941005035175
https://www.zhihu.com/zvideo/1993908940069699915/
https://www.zhihu.com/zvideo/1993908940069699915
https://www.zhihu.com/zvideo/1993908934109573278/
https://www.zhihu.com/zvideo/1993908934109573278
https://www.zhihu.com/zvideo/1993908933191037953/
https://www.zhihu.com/zvideo/1993908933191037953
https://www.zhihu.com/zvideo/1993908931861446751/
https://www.zhihu.com/zvideo/1993908931861446751
https://www.zhihu.com/zvideo/1993908925066650081/
https://www.zhihu.com/zvideo/1993908925066650081
https://www.zhihu.com/zvideo/1993908923359580411/
https://www.zhihu.com/zvideo/1993908923359580411
https://www.zhihu.com/zvideo/1993908922080313621/
https://www.zhihu.com/zvideo/1993908922080313621
https://www.zhihu.com/zvideo/1993908907127641011/
https://www.zhihu.com/zvideo/1993908907127641011
https://www.zhihu.com/zvideo/1993908900202840925/
https://www.zhihu.com/zvideo/1993908900202840925
https://www.zhihu.com/zvideo/1993908885128508038/
https://www.zhihu.com/zvideo/1993908885128508038

代码功能说明

  1. PaxosNode 类:模拟单个节点的提案(prepare)和接受(accept)逻辑。
  2. prepare 方法:节点承诺不接受比当前提案 ID 更小的请求。
  3. accept 方法:节点在提案 ID 有效时接受值并更新状态。
  4. 集群模拟:通过半数以上节点的承诺达成一致性。

输出示例

Node 0 prepare response: {'status': 'promised', 'accepted_value': None} Node 1 prepare response: {'status': 'promised', 'accepted_value': None} Node 2 prepare response: {'status': 'promised', 'accepted_value': None} Node 0 accept response: {'status': 'accepted'} Node 1 accept response: {'status': 'accepted'} Node 2 accept response: {'status': 'accepted'}

关键注意事项

  • 实际分布式系统需处理网络延迟、节点故障等复杂场景。
  • Paxos 变种(如 Raft)通过领导者选举简化实现。
  • CAP 权衡:选择 CP(如 ZooKeeper)或 AP(如 Cassandra)取决于业务需求。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/20 8:11:35

ResNet18应用案例:野生动物监测系统搭建

ResNet18应用案例:野生动物监测系统搭建 1. 引言:从通用识别到生态守护 1.1 通用物体识别的现实价值 在人工智能赋能各行各业的今天,图像分类技术已成为连接物理世界与数字系统的桥梁。其中,ResNet18 作为深度残差网络家族中最…

作者头像 李华
网站建设 2026/4/6 15:42:23

ResNet18应用场景:智能家居场景识别

ResNet18应用场景:智能家居场景识别 1. 引言:通用物体识别中的ResNet18价值 在智能设备日益普及的今天,场景理解能力已成为智能家居系统的核心竞争力之一。从自动调节灯光氛围到安防异常检测,系统能否“看懂”当前环境&#xff…

作者头像 李华
网站建设 2026/4/20 0:22:20

ResNet18部署教程:快速实现高精度物体识别系统

ResNet18部署教程:快速实现高精度物体识别系统 1. 引言 1.1 通用物体识别的现实需求 在智能安防、内容审核、自动驾驶和增强现实等众多领域,通用物体识别已成为AI应用的核心能力之一。用户期望系统不仅能识别“猫”或“汽车”,还能理解更复…

作者头像 李华
网站建设 2026/4/18 13:05:52

ResNet18实战教程:智能家居物品识别系统搭建

ResNet18实战教程:智能家居物品识别系统搭建 1. 教程目标与背景 随着智能家居设备的普及,让系统具备“看懂”环境的能力成为提升用户体验的关键。通用物体识别技术能够帮助智能设备理解用户所处场景、识别日常物品,从而实现更自然的人机交互…

作者头像 李华
网站建设 2026/4/19 16:39:43

FPGA中数字电路构建软件无线电:通信设备完整示例

FPGA构建软件无线电:从数字电路到通信系统实战你有没有遇到过这样的场景?一台设备刚发布就支持5G,半年后突然“升级”支持卫星通信——背后的秘密武器,很可能就是FPGA 软件无线电(SDR)。在传统通信系统中&…

作者头像 李华
网站建设 2026/4/16 20:45:36

ResNet18部署指南:解决内存泄漏问题

ResNet18部署指南:解决内存泄漏问题 1. 背景与挑战:通用物体识别中的稳定性需求 在AI推理服务的实际部署中,模型的功能实现只是第一步,真正的挑战在于长期运行的稳定性。尤其是在边缘设备或资源受限环境中,一个看似微…

作者头像 李华