Reminder
Final Project: Short video due next Wednesday
- Not more than 10 minutes
- Simple presentation, audience = classmates
- Describe problem you solved
- Overview of solution method (sequential)
- Opportunities for parallelism
- Challenges and/or successes
- Don’t need final results!
- Simplest method: record in Zoom
Last Time
Introduced the consensus problem:
- $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.
- 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
Roadmap
- Model
- atomic read/write registers
- Bivalent executions
- executions that can be extended to produce output 0 or 1
- Critical executions
- if any processor takes a step, then output is determined
- Proof of FLP result
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 Algorithm
Default to 0
: output 0
unless all processes have input 1
int in = getLocalInput();
int i = ThreadId.get();
write(i, in); // write my value to register i
if (in == 0) return 0;
for (int j = 0; j < nProcesses; j++) {
// wait until register j has been written
while (read(j) != 0 && read(j) != 1) { };
if (read(j) == 0) return 0;
}
// all processors have in == 1
return 1;
Example of Execution $E$
data:image/s3,"s3://crabby-images/8f224/8f224ea79127650c37db1216a5270a56c631cd23" alt=""
$E$ Step 01
data:image/s3,"s3://crabby-images/86948/8694898b8a0a107fa53196005676df9b7fc3a0eb" alt=""
$E$ Step 02
data:image/s3,"s3://crabby-images/91491/91491389364b7554ac83c8619a48eadb82dfce38" alt=""
$E$ Step 03
data:image/s3,"s3://crabby-images/25cd1/25cd17b67e91c969a4c5f577a6c62c2dfbeedb7c" alt=""
$E$ Step 04
data:image/s3,"s3://crabby-images/37c3e/37c3ec570ee8d0be3cdb61cc27adc09aafc3339a" alt=""
$E$ Step 05
data:image/s3,"s3://crabby-images/e91fb/e91fb1e2408052a2465205ce0b7ef1b0e7fba92b" alt=""
$E$ Step 06
data:image/s3,"s3://crabby-images/abaab/abaab3e7829048bc45d1ca84437f7bfbf7ea9454" alt=""
Extending Executions
In $E$, no process has terminated yet
- We can consider extensions of a given execution
- Start with $E$, and perform more steps
$E’$ Step 06
data:image/s3,"s3://crabby-images/abaab/abaab3e7829048bc45d1ca84437f7bfbf7ea9454" alt=""
$E’$ Step 07
data:image/s3,"s3://crabby-images/ac00a/ac00a2d07e25eac2d4d96ab2aa5158a9a045540e" alt=""
$E’$ Step 08
data:image/s3,"s3://crabby-images/40fbb/40fbb836f249ef5d9344b802a80adae5e1e3eb4d" alt=""
$E’$ Step 09
data:image/s3,"s3://crabby-images/84eae/84eae6b517d81f9486062288ede534ca67bea923" alt=""
$E’$ Step 10
data:image/s3,"s3://crabby-images/f51d2/f51d2b941d770e95238fec9ca09ff288c554cf44" alt=""
Note
We can consider many different extensions of $E$
Extension $E’$ of $E$
data:image/s3,"s3://crabby-images/f51d2/f51d2b941d770e95238fec9ca09ff288c554cf44" alt=""
Alternate extension $E’’$
data:image/s3,"s3://crabby-images/0c9e4/0c9e4d864c95a1fc76eeb60298891c8b54270167" 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
$E’$ for P1
data:image/s3,"s3://crabby-images/bf22d/bf22d51b0e83dc3f7294bf270a27942dad800c7f" alt=""
$E’’$ for P1
data:image/s3,"s3://crabby-images/efd39/efd39ed93edf7838fa22e210035676eed9e9c92f" alt=""
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’$
Properties of Consensus Protocols
Main argument for FLP:
- Describe properties that any hypothetical consensus protocol must have
-
bivalent executions
-
critical executions
- Use these properties to show that with only read/write registers there are indistinguishable executions that must give different outputs
Bivalent Executions
- Consider a (hypothetical) wait-free consensus protocol $A$
- Let $E$ be an execution of $A$
We say that $E$ is…
-
$0$-valent if in every extension of $E$, all processes output $0$
-
$1$-valent if in every extension of $E$, all processes output $1$
-
univalent if it is $0$- or $1$-valent
-
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$
- Such a state exists by Lemma 2
- If $E_0$ is critical, we’re done
- Otherwise form $E_0, E_1, E_2, \ldots$ where
- each $E_{i+1}$ extends $E_i$ by single step
- each $E_i$ is bivalent
- By wait-freedom, the sequence must be finite
- So it has a final $E$ where every extension is univalent
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