news 2026/6/10 0:43:11

分布式系统入门: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/6/9 19:44:20

ResNet18性能测试:长期运行稳定性

ResNet18性能测试:长期运行稳定性 1. 通用物体识别中的ResNet-18角色定位 在深度学习推动计算机视觉发展的进程中,图像分类作为最基础也最关键的一步,承担着从原始像素中提取语义信息的重任。其中,ResNet-18 凭借其简洁高效的架…

作者头像 李华
网站建设 2026/6/9 19:47:32

树莓派插针定义一文说清:I2C接口位置与作用

树莓派I2C接口全解析:从插针定义到实战应用你是不是也曾在接线时对着树莓派那40个密密麻麻的引脚发愁?明明只打算连一个温湿度传感器,结果却因为搞不清SDA和SCL到底对应哪两个物理引脚而卡住半天。更别提设备不识别、通信失败、地址冲突……这…

作者头像 李华
网站建设 2026/6/9 22:13:52

ResNet18性能优化:提升推理速度的7个技巧

ResNet18性能优化:提升推理速度的7个技巧 1. 背景与挑战:通用物体识别中的ResNet-18 在当前AI应用广泛落地的背景下,通用物体识别已成为智能监控、内容审核、辅助驾驶和AR交互等场景的核心能力。其中,ResNet-18作为经典轻量级卷…

作者头像 李华
网站建设 2026/6/9 22:45:42

ResNet18模型对比:与VGG16的性能评测

ResNet18模型对比:与VGG16的性能评测 1. 引言:为何需要深度网络架构对比? 随着计算机视觉任务在工业界和消费级应用中的广泛落地,图像分类已成为AI基础能力之一。在众多经典卷积神经网络(CNN)架构中&…

作者头像 李华
网站建设 2026/6/9 20:58:36

ResNet18部署案例:游戏场景识别系统实战

ResNet18部署案例:游戏场景识别系统实战 1. 引言:通用物体识别的工程落地需求 在当前AI应用快速普及的背景下,通用图像分类已成为智能内容理解、自动化标注、增强现实和游戏分析等场景的核心能力。尽管深度学习模型层出不穷,但在…

作者头像 李华
网站建设 2026/6/9 21:32:30

ResNet18教程:如何实现Top-3置信度展示

ResNet18教程:如何实现Top-3置信度展示 1. 引言 1.1 通用物体识别的现实需求 在智能设备、内容审核、辅助驾驶和AR/VR等场景中,快速准确地理解图像内容已成为基础能力。通用物体识别任务要求模型能够对日常生活中常见的上千类物体与场景进行分类&…

作者头像 李华