Lecture 25: Consensus & Beyond
Reminders
Final Project:
- Short video due today
- Final submission next Friday, May 28, 5pm Eastern
All submissions to Google drive folder
Last Time
Consensus
- $n$ processes, each with private input
- some processes may crash
- must produce output satisfying following properties
-
Agreement: all processes output the same value
-
Validity: if all systems have the same input, they all output that value
-
Termination: all (non-faulty) processes decide on an output and terminate after a finite number of steps
Our Goal
Theorem (FLP, 1985). There is no algorithm that achieves consensus in the presence of even a single faulty process.
- Assumes atomic read/write shared memory
- Special case: there is no wait-free protocol for consensus for any $n > 1$
- wait-free is stronger assumption than termination
- Consider binary consensus all inputs 0/1
Also Last Time
Lemma 2. Suppose $A$ solves consensus. Then there is a bivalent initial state.
- Recall a bivalent execution (or initial state) is an execution from which the output could be 0 or 1 (depending or scheduler)
Lemma 3. Every consensus protocol has a critical execution.
- $E$ is a critical execution if it is bivalent, but every extension of $E$ is univalent
- any process taking a single step from $E$ determines the output
These properties hold for all consensus protocols
Today
Finish the proof of FLP
Outline of Proof of FLP
Assume only 2 processes, $P_0$ and $P_1$
- Start from a critical execution $E$
- $E$ is bivalent, but any extension is univalent
- Consider all possibilities for next step:
- both threads
read
for next step
- one thread
read
s, the other write
s
- both threads
write
- Show that in any case, we contradict either criticality of
E
or correctness of protocol
Assumptions
Without loss of generality:
- There are two processes $P_0$ and $P_1$
- $E$ is a critical state
- if $P_0$ has next step, resulting execution is $0$-valent
- if $P_1$ has next step, resulting execution is $1$-valent
Case 1: read
/read
Assumption: next operations for both $P_0$ and $P_1$ are read
- Start from critical state $E$
- if $P_0$ steps next, output is
0
- if $P_1$ steps next, output is
1
read
/read
data:image/s3,"s3://crabby-images/b2c9d/b2c9d98980f61ead475c79fd04750c2fb9446da5" alt=""
read
/read
Next Step
data:image/s3,"s3://crabby-images/80d90/80d90f22d56a266e1c2cae3f77408f85f84f6b95" alt=""
read
/read
Problem
data:image/s3,"s3://crabby-images/44d0f/44d0f4ed5ccc4986c09faf9fb59891b36f4ef6b5" alt=""
Case 2: read
/write
Assumption:
read
/write
Setup
data:image/s3,"s3://crabby-images/11256/11256c1335b024199a676b908cf7460105e39202" alt=""
read
/write
Next Step
data:image/s3,"s3://crabby-images/0288c/0288c98dd975dae38f897c6b0593d7e1acb20506" alt=""
read
/write
Indistinguishable
data:image/s3,"s3://crabby-images/d14ee/d14ee7cfe3e4ca8ab1f9ff51c0d97a243b76e859" alt=""
read
/write
$P_0$ Crashes
data:image/s3,"s3://crabby-images/d14ee/d14ee7cfe3e4ca8ab1f9ff51c0d97a243b76e859" alt=""
Case 3: write
/write
Assumption: next operation for both $P_0$ and $P_1$ is write
Subcases:
- Sub-case a: write to different registers
- Sub-case b: write to same register
write
/write
Different Registers
data:image/s3,"s3://crabby-images/8cc0f/8cc0f852c534cc4a2c1f6747c7d4c2599843e2cd" alt=""
write
/write
Next Step
data:image/s3,"s3://crabby-images/6482e/6482ebf9758581d8c1da71567ce2a546291839f0" alt=""
write
/write
Indistinguishable
data:image/s3,"s3://crabby-images/4d693/4d693d26b98a3832cb63b54c101181823d93f61f" alt=""
write
/write
Same Register
data:image/s3,"s3://crabby-images/4ab8e/4ab8e01363165c8b56fdd76924396f71fb1fd729" alt=""
write
/write
Next Step
data:image/s3,"s3://crabby-images/00ec6/00ec698bed71ea92979d4eed216d75ca512c727f" alt=""
write
/write
Indistinguishable
data:image/s3,"s3://crabby-images/a1bb5/a1bb596a3dd744c244607737023858a42ba86fe7" alt=""
Conclusion
In general:
- Indistinguishable executions produce same output
Assuming a wait-free consensus protocol using only read/write registers:
- Showed there is a bivalent initial state
- Showed there is a critical execution
- Given a critical execution
- found indistinguishable states that must give different outputs
- this is a contradiction!
Remark. 1 and 2 hold for all protocols; 3 assumes only read/write registers
Consensus is Impossible?
Well not quite!
- We just proved impossibility in our computational model!
- atomic read/write registers
- wait-free (or faults)
- nasty scheduler!
Does the Model Reflect Reality?
- we have stronger primitives!
- we might have better schedulers
- faults could be worse
Implications
- Atomic read/write registers are insufficient to solve fundamental tasks in parallel computing
- this drives the development of hardware primitives (e.g. CAS)
- We can quantify the computational power of primitive operations
- read/write registers have consensus number 1
- FIFO queues have consensus number 2
- given a wait-free queue, 2 threads can solve consensus (How?)
- $\implies$ cannot implement concurrent queues with read/write registers
- Can use
compareAndSet
to achieve consensus (How?)
Four Morals
- Parallelism is powerful
- Communication is expensive
- cache locality and performance
- Synchronization is subtle
- locks
- concurrent data structures
- impossibility (FLP)
- Theory meets practice
- cannot reason about correctness/performance without understanding hardware
- hardare design informed by theory (e.g. atomics)