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/10 13:19:38

ResNet18应用技巧:模型微调提升特定场景准确率

ResNet18应用技巧:模型微调提升特定场景准确率 1. 引言:通用物体识别中的ResNet-18价值 在当前AI视觉应用广泛落地的背景下,通用图像分类已成为智能系统的基础能力之一。其中,ResNet-18作为深度残差网络家族中最轻量且高效的成员…

作者头像 李华
网站建设 2026/6/10 13:21:58

三极管驱动LED灯电路在单片机控制下的实践应用

用三极管点亮LED:单片机驱动能力不足的优雅解法你有没有遇到过这种情况——写好了代码,下载进单片机,结果LED就是不亮?或者勉强亮了,但亮度暗得像快没电的手电筒?更糟的是,MCU莫名其妙复位&…

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

ResNet18应用教程:医学影像的自动分类

ResNet18应用教程:医学影像的自动分类 1. 引言:通用物体识别与ResNet-18的工程价值 在计算机视觉领域,图像分类是许多高级任务(如目标检测、语义分割)的基础。其中,ResNet-18 作为残差网络(Re…

作者头像 李华
网站建设 2026/6/10 13:00:04

ResNet18优化案例:模型剪枝与加速技术

ResNet18优化案例:模型剪枝与加速技术 1. 引言:通用物体识别中的ResNet-18挑战与机遇 1.1 业务场景与技术背景 在当前AI应用广泛落地的背景下,通用图像分类已成为智能监控、内容审核、辅助驾驶和AR/VR等场景的基础能力。其中,R…

作者头像 李华
网站建设 2026/6/10 15:04:55

Multisim主数据库连接失败:入门必看配置步骤详解

Multisim主数据库连接失败?别慌,这份实战修复指南帮你从崩溃到秒启你有没有遇到过这种情况:刚打开Multisim准备仿真一个放大电路,结果弹窗冷不丁跳出一句“无法连接到主数据库”——然后左边元件栏一片空白,连电阻都拖…

作者头像 李华
网站建设 2026/6/10 12:54:27

ResNet18部署案例:农业病虫害识别系统实战

ResNet18部署案例:农业病虫害识别系统实战 1. 引言:从通用物体识别到农业场景落地 在现代农业智能化转型中,实时、精准的病虫害识别是提升作物管理效率的关键环节。传统依赖人工经验的判断方式存在响应慢、误判率高、覆盖范围有限等问题。随…

作者头像 李华