Paxos phase-1 要求
Proposer 生产一个整数 n 来作为 rnd
.
实际上 rnd
的定义从整数推广到任意的 偏序关系 的值, 也同样能满足 Paxos 的正确性, 因为 Paxos 中主要只用到了 rnd
的大小关系的性质.
使用偏序 rnd
的 Paxos,
可以选择强制的冲突互斥(类似2PC)
或是非强制的冲突互斥(类似Paxos的活锁)来实现一致性协议的安全性要求.
例如选择 整除 的偏序关系实现 Paxos, 定义 rnd
为正整数,
大小关系定义: 为如果 a 整除 b, 那么 a 才小于 b:
这时有: 1 < 2 < 6
, 1 < 3 < 6
, 但是 2 ≮ 3
.
如下例子中, Proposer P2 完成 phase-1 后, P3 无法完成 phase-1, 因为 Acceptor A2 上 3 ≯ 2
, 于是放弃 P3, 使用 P6 完成 phase-1, 进而再完成 phase-2, 完成一次commit.
在应用上, 偏序的 rnd
给 Paxos 等一致性算法提供了非常大的扩展空间,
它将一维的先后关系扩展到多维度的先后关系(类似多维的时间).
例如对一个存储系统可以设置 2 组 rnd
:
- 一组 Proposer 只选择 2ⁿ 的
rnd
, 希望执行事务A; - 一组 Proposer 只选择 3ⁿ 的
rnd
, 希望执行事务B;
于是这两组 Proposer 之间互斥, 保证了最多只有一个事务成功(不会产生 Paxos 中的活锁). 而组内多个 Proposer 之间又可以形成高可用的互备(不存在 2PC 中 Coordinator 宕机的问题).
所以, 偏序 Paxos 可以提供 2PC 的事务互斥性, 也提供了 Paxos 的故障容忍, 可以将分布式DB(例如spanner) 中的 2PC + Paxos 的两层架构简化成一层.