
AP 模式的业务场景与实现
在分布式系统中,实现数据一致性往往面临挑战。CAP 理论提出了一致性(C)、可用性(A)和分区容忍性(P)三项特性不能同时满足,因此需要权衡选择。
AP 模式:最终一致性思想
AP 模式放弃了强一致性,转而追求数据的最终一致性。这意味着系统中的数据可能在一段时间内保持不一致,但最终会收敛到一致的状态。
业务场景:
”扩展PHP“说起来容易做起来难。PHP已经进化成一个日趋成熟的源码包几十兆大小的工具。要骇客如此复杂的一个系统,不得不学习和思考。构建本章内容时,我们最终选择了“在实战中学习”的方式。这不是最科学也不是最专业的方式,但是此方式最有趣,也得出了最好的最终结果。下面的部分,你将先快速的学习到,如何获得最基本的扩展,且这些扩展立即就可运行。然后你将学习到 Zend 的高级 API 功能,这种方式将不得
- 允许短暂不一致:例如,社交媒体平台上的点赞数。虽然点赞请求可能不会立即更新到所有节点上,但最终所有节点都会收到更新,从而达到一致。
- 聚合数据:例如,统计网站的访问量。即使数据在不同节点上稍有不同,但最终汇总后的结果仍然是有意义的。
- 用户注册:即使注册过程中的某些信息在不同系统之间未立即同步,只要用户能够成功注册,系统最终会通过补偿机制处理这些不一致性。
实现形式:
AP 模式可以通过以下技术实现:
- 异步复制:数据更新从一个主副本复制到其他副本,但无需等待所有的副本都更新完成。
- 消息队列:事务操作通过消息队列传递,以便各个组件异步处理更新。
- 补偿机制:系统通过补偿机制处理不一致性,例如通过补偿日志记录和重放机制来弥补丢失的更新。
CP vs. AP 的选择
CP 和 AP 模式的选择取决于具体的业务需求:
- CP 模式:对于事务操作的关键数据,需要保证强一致性,例如银行转账。
- AP 模式:对于允许短暂不一致的数据,例如社交媒体点赞数,AP 模式更合适。









