Lecture 36: Consensus II
COSC 273: Parallel and Distributed Computing
Spring 2023
Annoucements
- Quiz due tonight
- Leaderboard 3 submissions, run Sunday morning
- Final Submissions: Tuesday, 05/09 by 5:00pm
- documentation = 40% of grade
Leaderboard 2
Primes Task (baseline 58810ms):
- The AMA (2070ms)
- Test Group Name Please Ignore (3530ms)
- Deadlock Dodgers (4467ms)
Sorting Task (baseline 8034ms):
- Deadlock Dodgers (1548ms)
- MRC (1550ms)
- Benchmark (2013ms)
Binary Consensus
Setup: $n$ processes with binary inputs
-
Agreement: all processes output the same value
-
Validity: if all systems have the same input, they all output that valuex
-
Termination: all (non-faulty) processes decide on an output and terminate after a finite number of steps
Theorem (FLP, 1985). There is no algorithm that achieves consensus in the presence of even a single faulty process.
Today
We’ll prove:
Theorem. There is no wait-free protocol for consensus for shared memory with atomic read/write access.
-
wait-free means each process completes in a bounded number of steps, indpendent of actions of other threads
Game Plan
Theorem. There is no wait-free protocol for consensus for shared memory with atomic read/write registers.
- Define indistinguishability of executions
-
Lemma 1. indistinguishable executions have same results
- Define bivalent execution
- the final output (all 0s or all 1s) has not yet been determined
-
Lemma 2 Show there is a bivalent initial state
- Define critical executions: if any process takes a step, then output is determined
-
Lemma 3 Every protocol has a critical execution
Executions
An execution $E$ of algorithm $A$ specifies
- Inputs of all processes
- Sequence of steps taken by processes
- read, write, terminate, crash
Executions may be incomplete
- Not all nodes have terminated/crashed yet
- encodes current state/history of execution
Executions may be extended by scheduling more steps
Example of Execution $E$
data:image/s3,"s3://crabby-images/abaab/abaab3e7829048bc45d1ca84437f7bfbf7ea9454" alt=""
Indistinguishable Executions
- $E$ and $E’$ are executions
- they are indistinguishable at process $P_i$ if in $E$ and $E’$:
- $P_i$ has same input
- sequence of read/write operations performed by $P_i$ are same
- the sequence of values read and written by $P_i$ are the same
First Important Observation
Lemma 1. If executions $E$ and $E’$ are indistinguishable to process $P_i$ then:
- If $P_i$ has not yet terminated, then $P_i$’s next step will be the same in any extension
- If $P_i$ has terminated, then $P_i$’s output is the same in $E$ and $E’$
Bivalent Executions
- Consider a (hypothetical) wait-free consensus protocol $A$
- Let $E$ be an execution of $A$
We say that $E$ is…
-
$0$-valent: in every extension of $E$, all processes output $0$
-
$1$-valent: in every extension of $E$, all processes output $1$
-
bivalent if there exist
- an extension $E’$ of $E$ in which all processes output $0$
- an extension $E’’$ of $E$ in which all processes output $1$
Second Important Observation
Lemma 2. Suppose $A$ solves consensus. Then there is a bivalent initial state.
- Here an initial state is an execution in which no process has yet taken a step
- the execution consists of only inputs for each process
Proof of Lemma 2
Must show: there is a bivalent initial state
Argument:
- by contradiction: suppose no bivalent initial state
- consider sequence of initial states
- show some are $0$-valent, some are $1$-valent
- show that some must be bivalent
$E_1$ is $0$-valent (Why?)
data:image/s3,"s3://crabby-images/8dcd6/8dcd68fc0ce653c3b6e9b44e10b6864645112fa5" alt=""
$E_5$ is $1$-valent
data:image/s3,"s3://crabby-images/eba78/eba780bfa8b0c9d57a7149690fc5be386fcab535" alt=""
More Initial States
data:image/s3,"s3://crabby-images/f3043/f3043af4a3822a7747df8128b171183bee43e32f" alt=""
Assume: All Univalent
data:image/s3,"s3://crabby-images/474ca/474ca424706e803d1bc2764e875ed28d9b647316" alt=""
Adjacent Pair, Different Valency
data:image/s3,"s3://crabby-images/5389e/5389e9aabbce2a9cfc038515711b53b5522e91aa" alt=""
All Extensions of $E_2$ Return $0$
data:image/s3,"s3://crabby-images/91324/91324aefc1c6e5579a37c5792977716cddd3d44d" alt=""
All Extensions of $E_3$ Return $1$
data:image/s3,"s3://crabby-images/dd7f7/dd7f79459cd340e590955d509a80c9d1f45fc428" alt=""
$E_2’$ and $E_3’$ Indistinguishable
data:image/s3,"s3://crabby-images/f3ac6/f3ac60a563abf845e949fe52eadbef85ff4f0d95" alt=""
$E_2$ and $E_3$ Bivalent
data:image/s3,"s3://crabby-images/6c6b7/6c6b7bf3d4bc1114edaf5d64095447ee338f100f" alt=""
Note
Don’t need to assume $P_2$ crashes
- just assume first step of $P_2$ is scheduled after some other thread outputs
- this is possible because we assume $A$ is wait-free
- some process guaranteed to terminate even if one is not scheduled
Mere possibility of a crash together with wait-free assumption implies existence a bivalent initial state
- same holds if we require only termination with one fault
Critical Executions
An execution $E$ is critical if:
- $E$ is bivalent
- Extending $E$ by any single step of any process results in a univalent execution
Important Obvservation 3
Lemma 3. Every consensus protocol has a critical execution.
Proof of Lemma 3
Consider a bivalent initial state $E_0$
- Why does such a state exist?
Properties of Consensus
Lemma 2. Every consensus protocol has a bivalent initial state.
Lemma 3. Every consensus protocol has a citical execution $E$.
So far: Have not used any properties of atomic read/write registers
- These properties hold for all consensus protocols
- even if other atomic operations are supported
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