Understanding Replica Management in Computing Systems and Concurrency

 
V
i
e
w
 
C
h
a
n
g
e
 
P
r
o
t
o
c
o
l
s
 
a
n
d
R
e
c
o
n
f
i
g
u
r
a
t
i
o
n
 
CS 240: Computing Systems and Concurrency
Lecture 11
 
Marco Canini
 
1.
M
o
r
e
 
p
r
i
m
a
r
y
-
b
a
c
k
u
p
 
r
e
p
l
i
c
a
t
i
o
n
 
2.
View changes
 
3.
Reconfiguration
 
2
 
T
o
d
a
y
 
N
o
m
i
n
a
t
e
 
o
n
e
 
r
e
p
l
i
c
a
 
p
r
i
m
a
r
y
C
l
i
e
n
t
s
 
s
e
n
d
 
a
l
l
 
r
e
q
u
e
s
t
s
 
t
o
 
p
r
i
m
a
r
y
P
r
i
m
a
r
y
 
o
r
d
e
r
s
 
c
l
i
e
n
t
s
 
r
e
q
u
e
s
t
s
 
 
 
R
e
v
i
e
w
:
 
p
r
i
m
a
r
y
-
b
a
c
k
u
p
 
r
e
p
l
i
c
a
t
i
o
n
 
3
 
L
o
g
 
L
o
g
g
i
n
g
M
o
d
u
l
e
 
S
t
a
t
e
M
a
c
h
i
n
e
 
L
o
g
 
L
o
g
g
i
n
g
M
o
d
u
l
e
 
S
t
a
t
e
M
a
c
h
i
n
e
 
C
l
i
e
n
t
s
 
shl
 
S
e
r
v
e
r
s
 
Primary-Backup with many replicas
P
r
i
m
a
r
y
 
w
a
i
t
s
 
f
o
r
 
a
c
k
n
o
w
l
e
d
g
e
m
e
n
t
 
f
r
o
m
 
a
l
l
 
b
a
c
k
u
p
s
All updates to set of replicas needs to update shared
disk (recall VM-FT)
 
4
 
F
r
o
m
 
t
w
o
 
t
o
 
m
a
n
y
 
r
e
p
l
i
c
a
s
 
L
o
g
 
L
o
g
g
i
n
g
M
o
d
u
l
e
 
S
t
a
t
e
M
a
c
h
i
n
e
 
L
o
g
 
L
o
g
g
i
n
g
M
o
d
u
l
e
 
S
t
a
t
e
M
a
c
h
i
n
e
 
L
o
g
 
L
o
g
g
i
n
g
M
o
d
u
l
e
 
S
t
a
t
e
M
a
c
h
i
n
e
 
C
l
i
e
n
t
s
 
shl
 
S
e
r
v
e
r
s
 
V
i
e
w
s
t
a
m
p
e
d
 
R
e
p
l
i
c
a
t
i
o
n
:
S
t
a
t
e
 
M
a
c
h
i
n
e
 
R
e
p
l
i
c
a
t
i
o
n
 
f
o
r
 
a
n
y
 
n
u
m
b
e
r
 
o
f
r
e
p
l
i
c
a
s
R
e
p
l
i
c
a
 
g
r
o
u
p
:
 
G
r
o
u
p
 
o
f
 
2
f
 
+
 
1
 
r
e
p
l
i
c
a
s
P
r
o
t
o
c
o
l
 
c
a
n
 
t
o
l
e
r
a
t
e
 
f
 
r
e
p
l
i
c
a
 
c
r
a
s
h
e
s
 
Differences with primary-backup
No shared disk (no reliable failure detection)
D
o
n
t
 
n
e
e
d
 
t
o
 
w
a
i
t
 
f
o
r
 
a
l
l
 
r
e
p
l
i
c
a
s
 
t
o
 
r
e
p
l
y
Need more replicas to handle 
f 
 failures
(2
f+
1 vs 
f+
1)
 
5
 
W
h
a
t
 
e
l
s
e
 
c
a
n
 
w
e
 
d
o
 
w
i
t
h
 
m
o
r
e
 
r
e
p
l
i
c
a
s
?
 
V
i
e
w
s
t
a
m
p
e
d
 
R
e
p
l
i
c
a
t
i
o
n
:
S
t
a
t
e
 
M
a
c
h
i
n
e
 
R
e
p
l
i
c
a
t
i
o
n
 
f
o
r
 
a
n
y
 
n
u
m
b
e
r
 
o
f
r
e
p
l
i
c
a
s
R
e
p
l
i
c
a
 
g
r
o
u
p
:
 
G
r
o
u
p
 
o
f
 
2
f
 
+
 
1
 
r
e
p
l
i
c
a
s
P
r
o
t
o
c
o
l
 
c
a
n
 
t
o
l
e
r
a
t
e
 
f
 
r
e
p
l
i
c
a
 
c
r
a
s
h
e
s
 
Assumptions:
1.
H
a
n
d
l
e
s
 
c
r
a
s
h
 
f
a
i
l
u
r
e
s
 
o
n
l
y
:
 
R
e
p
l
i
c
a
s
 
f
a
i
l
 
o
n
l
y
 
b
y
c
o
m
p
l
e
t
e
l
y
 
s
t
o
p
p
i
n
g
2.
U
n
r
e
l
i
a
b
l
e
 
n
e
t
w
o
r
k
:
 
M
e
s
s
a
g
e
s
 
m
i
g
h
t
 
b
e
 
l
o
s
t
,
d
u
p
l
i
c
a
t
e
d
,
 
d
e
l
a
y
e
d
,
 
o
r
 
d
e
l
i
v
e
r
e
d
 
o
u
t
-
o
f
-
o
r
d
e
r
 
6
 
W
i
t
h
 
m
u
l
t
i
p
l
e
 
r
e
p
l
i
c
a
s
,
 
d
o
n
t
 
n
e
e
d
 
t
o
 
w
a
i
t
f
o
r
 
a
l
l
 
1.
c
o
n
f
i
g
u
r
a
t
i
o
n
:
 
i
d
e
n
t
i
t
i
e
s
 
o
f
 
a
l
l
 
2
f
 
+
 
1
 
r
e
p
l
i
c
a
s
 
2.
I
n
-
m
e
m
o
r
y
 
l
o
g
 
w
i
t
h
 
c
l
i
e
n
t
s
 
r
e
q
u
e
s
t
s
 
i
n
 
a
s
s
i
g
n
e
d
 
o
r
d
e
r
 
7
 
R
e
p
l
i
c
a
 
s
t
a
t
e
 
.
.
.
 
1.
Primary adds request to end of its log
 
2.
Replicas add requests to their logs in primary’s log order
 
3.
P
r
i
m
a
r
y
 
w
a
i
t
s
 
f
o
r
 
f
 
P
r
e
p
a
r
e
O
K
s
 
 
r
e
q
u
e
s
t
 
i
s
 
c
o
m
m
i
t
t
e
d
Makes up-call to execute the operation
8
N
o
r
m
a
l
 
o
p
e
r
a
t
i
o
n
C
l
i
e
n
t
A
 
(
P
r
i
m
a
r
y
)
B
C
T
i
m
e
 
R
e
q
u
e
s
t
(
f
 
=
 
1
)
 
P
r
o
t
o
c
o
l
 
g
u
a
r
a
n
t
e
e
s
 
s
t
a
t
e
 
m
a
c
h
i
n
e
 
r
e
p
l
i
c
a
t
i
o
n
 
O
n
 
e
x
e
c
u
t
e
,
 
p
r
i
m
a
r
y
 
k
n
o
w
s
 
r
e
q
u
e
s
t
 
i
n
 
f
 
+
 
1
 
=
 
2
 
n
o
d
e
s
 
l
o
g
s
E
v
e
n
 
i
f
 
f
 
=
 
1
 
t
h
e
n
 
c
r
a
s
h
,
 
 
1
 
r
e
t
a
i
n
s
 
r
e
q
u
e
s
t
 
i
n
 
l
o
g
9
N
o
r
m
a
l
 
o
p
e
r
a
t
i
o
n
:
 
K
e
y
 
p
o
i
n
t
s
C
l
i
e
n
t
A
 
(
P
r
i
m
a
r
y
)
B
C
T
i
m
e
 
R
e
q
u
e
s
t
(
f
 
=
 
1
)
 
P
r
e
v
i
o
u
s
 
R
e
q
u
e
s
t
s
 
c
o
m
m
i
t
 
p
i
g
g
y
b
a
c
k
e
d
 
o
n
 
c
u
r
r
e
n
t
 
P
r
e
p
a
r
e
 
No client Request after a timeout period?
P
r
i
m
a
r
y
 
s
e
n
d
s
 
C
o
m
m
i
t
 
m
e
s
s
a
g
e
 
t
o
 
a
l
l
 
b
a
c
k
u
p
 
r
e
p
l
i
c
a
s
10
10
P
i
g
g
y
b
a
c
k
e
d
 
c
o
m
m
i
t
s
C
l
i
e
n
t
A
 
(
P
r
i
m
a
r
y
)
B
C
T
i
m
e
 
R
e
q
u
e
s
t
(
f
 
=
 
1
)
 
+
C
o
m
m
i
t
 
p
r
e
v
i
o
u
s
 
S
o
 
f
a
r
:
 
W
o
r
k
s
 
f
o
r
 
f
 
f
a
i
l
e
d
 
b
a
c
k
u
p
 
r
e
p
l
i
c
a
s
 
B
u
t
 
w
h
a
t
 
i
f
 
t
h
e
 
f
 
f
a
i
l
u
r
e
s
 
i
n
c
l
u
d
e
 
a
 
f
a
i
l
e
d
 
p
r
i
m
a
r
y
?
A
l
l
 
c
l
i
e
n
t
s
 
r
e
q
u
e
s
t
s
 
g
o
 
t
o
 
t
h
e
 
f
a
i
l
e
d
 
p
r
i
m
a
r
y
S
y
s
t
e
m
 
h
a
l
t
s
 
d
e
s
p
i
t
e
 
m
e
r
e
l
y
 
f
 
f
a
i
l
u
r
e
s
11
11
T
h
e
 
n
e
e
d
 
f
o
r
 
a
 
v
i
e
w
 
c
h
a
n
g
e
 
1.
More primary-backup replication
 
2.
V
i
e
w
 
c
h
a
n
g
e
s
W
i
t
h
 
V
i
e
w
s
t
a
m
p
e
d
 
R
e
p
l
i
c
a
t
i
o
n
Using a View Server
 
3.
Reconfiguration
 
12
12
 
T
o
d
a
y
 
L
e
t
 
d
i
f
f
e
r
e
n
t
 
r
e
p
l
i
c
a
s
 
a
s
s
u
m
e
 
r
o
l
e
 
o
f
 
p
r
i
m
a
r
y
 
o
v
e
r
 
t
i
m
e
 
S
y
s
t
e
m
 
m
o
v
e
s
 
t
h
r
o
u
g
h
 
a
 
s
e
q
u
e
n
c
e
 
o
f
 
v
i
e
w
s
V
i
e
w
 
=
 
(
v
i
e
w
 
n
u
m
b
e
r
,
 
p
r
i
m
a
r
y
 
i
d
,
 
b
a
c
k
u
p
 
i
d
,
 
.
.
.
)
 
13
13
 
V
i
e
w
s
 
V
i
e
w
 
#
1
,
 
#
4
,
 
 
V
i
e
w
 
#
2
,
 
#
5
,
 
 
V
i
e
w
 
#
3
,
 
#
6
,
 
B
a
c
k
u
p
 
r
e
p
l
i
c
a
s
 
m
o
n
i
t
o
r
 
p
r
i
m
a
r
y
I
f
 
p
r
i
m
a
r
y
 
s
e
e
m
s
 
f
a
u
l
t
y
 
(
n
o
 
P
r
e
p
a
r
e
/
C
o
m
m
i
t
)
:
B
a
c
k
u
p
s
 
e
x
e
c
u
t
e
 
t
h
e
 
v
i
e
w
 
c
h
a
n
g
e
 
p
r
o
t
o
c
o
l
 
t
o
s
e
l
e
c
t
 
n
e
w
 
p
r
i
m
a
r
y
V
i
e
w
 
c
h
a
n
g
e
s
 
e
x
e
c
u
t
e
 
a
u
t
o
m
a
t
i
c
a
l
l
y
,
 
r
a
p
i
d
l
y
14
14
V
i
e
w
 
c
h
a
n
g
e
 
p
r
o
t
o
c
o
l
N
e
e
d
 
t
o
 
k
e
e
p
 
c
l
i
e
n
t
s
 
a
n
d
 
r
e
p
l
i
c
a
s
 
i
n
 
s
y
n
c
:
 
s
a
m
e
l
o
c
a
l
 
s
t
a
t
e
 
o
f
 
t
h
e
 
c
u
r
r
e
n
t
 
v
i
e
w
S
a
m
e
 
l
o
c
a
l
 
s
t
a
t
e
 
a
t
 
c
l
i
e
n
t
s
S
a
m
e
 
l
o
c
a
l
 
s
t
a
t
e
 
a
t
 
r
e
p
l
i
c
a
s
 
V
i
e
w
 
c
h
a
n
g
e
s
 
h
a
p
p
e
n
 
l
o
c
a
l
l
y
 
a
t
 
e
a
c
h
 
r
e
p
l
i
c
a
 
O
l
d
 
p
r
i
m
a
r
y
 
e
x
e
c
u
t
e
s
 
r
e
q
u
e
s
t
s
 
i
n
 
t
h
e
 
o
l
d
 
v
i
e
w
,
 
n
e
w
p
r
i
m
a
r
y
 
e
x
e
c
u
t
e
s
 
r
e
q
u
e
s
t
s
 
i
n
 
t
h
e
 
n
e
w
 
v
i
e
w
 
W
a
n
t
 
t
o
 
e
n
s
u
r
e
 
s
t
a
t
e
 
m
a
c
h
i
n
e
 
r
e
p
l
i
c
a
t
i
o
n
 
 
S
o
 
c
o
r
r
e
c
t
n
e
s
s
 
c
o
n
d
i
t
i
o
n
:
 
C
o
m
m
i
t
t
e
d
 
r
e
q
u
e
s
t
s
1.
S
u
r
v
i
v
e
 
i
n
 
t
h
e
 
n
e
w
 
v
i
e
w
2.
R
e
t
a
i
n
 
t
h
e
 
s
a
m
e
 
o
r
d
e
r
 
i
n
 
t
h
e
 
n
e
w
 
v
i
e
w
15
15
M
a
k
i
n
g
 
t
h
e
 
v
i
e
w
 
c
h
a
n
g
e
 
c
o
r
r
e
c
t
 
1.
c
o
n
f
i
g
u
r
a
t
i
o
n
:
 
s
o
r
t
e
d
 
i
d
e
n
t
i
t
i
e
s
 
o
f
 
a
l
l
 
2
f
 
+
 
1
 
r
e
p
l
i
c
a
s
 
2.
I
n
-
m
e
m
o
r
y
 
l
o
g
 
w
i
t
h
 
c
l
i
e
n
t
s
 
r
e
q
u
e
s
t
s
 
i
n
 
a
s
s
i
g
n
e
d
 
o
r
d
e
r
 
3.
v
i
e
w
-
n
u
m
b
e
r
:
 
i
d
e
n
t
i
f
i
e
s
 
p
r
i
m
a
r
y
 
i
n
 
c
o
n
f
i
g
u
r
a
t
i
o
n
 
l
i
s
t
 
4.
s
t
a
t
u
s
:
 
n
o
r
m
a
l
 
o
r
 
i
n
 
a
 
v
i
e
w
-
c
h
a
n
g
e
 
16
16
 
R
e
p
l
i
c
a
 
s
t
a
t
e
 
(
f
o
r
 
v
i
e
w
 
c
h
a
n
g
e
)
 
1.
B
 
n
o
t
i
c
e
s
 
A
 
h
a
s
 
f
a
i
l
e
d
,
 
s
e
n
d
s
 
S
t
a
r
t
-
V
i
e
w
-
C
h
a
n
g
e
 
2.
C
 
r
e
p
l
i
e
s
 
D
o
-
V
i
e
w
-
C
h
a
n
g
e
 
t
o
 
n
e
w
 
p
r
i
m
a
r
y
,
 
w
i
t
h
 
i
t
s
 
l
o
g
 
3.
B
 
w
a
i
t
s
 
f
o
r
 
f
 
r
e
p
l
i
e
s
,
 
t
h
e
n
 
s
e
n
d
s
 
S
t
a
r
t
-
V
i
e
w
 
4.
On receipt of Start-View, C replays log, accepts new ops
17
17
V
i
e
w
 
c
h
a
n
g
e
 
p
r
o
t
o
c
o
l
B
 
(
N
e
w
 
P
r
i
m
a
r
y
)
C
T
i
m
e
 
(
!
)
 
+
+
v
i
e
w
 
#
(
f
 
=
 
1
)
 
O
l
d
 
p
r
i
m
a
r
y
 
A
 
m
u
s
t
 
h
a
v
e
 
r
e
c
e
i
v
e
d
 
o
n
e
 
o
r
 
t
w
o
 
P
r
e
p
a
r
e
O
K
r
e
p
l
i
e
s
 
f
o
r
 
t
h
a
t
 
r
e
q
u
e
s
t
 
(
w
h
y
?
)
 
R
e
q
u
e
s
t
 
i
s
 
i
n
 
B
s
 
o
r
 
C
s
 
l
o
g
 
(
o
r
 
b
o
t
h
)
:
 
s
o
 
i
t
 
w
i
l
l
 
s
u
r
v
i
v
e
i
n
t
o
 
n
e
w
 
v
i
e
w
18
18
V
i
e
w
 
c
h
a
n
g
e
 
p
r
o
t
o
c
o
l
:
 
C
o
r
r
e
c
t
n
e
s
s
B
 
(
N
e
w
 
P
r
i
m
a
r
y
)
C
T
i
m
e
 
 
P
r
e
p
a
r
e
O
K
E
x
e
c
u
t
e
d
 
r
e
q
u
e
s
t
,
p
r
e
v
i
o
u
s
 
v
i
e
w
A
 
(
O
l
d
 
P
r
i
m
a
r
y
)
(
f
 
=
 
1
)
 
A
n
y
 
g
r
o
u
p
 
o
f
 
f
 
+
 
1
 
r
e
p
l
i
c
a
s
 
i
s
 
c
a
l
l
e
d
 
a
 
q
u
o
r
u
m
 
Q
u
o
r
u
m
 
i
n
t
e
r
s
e
c
t
i
o
n
 
p
r
o
p
e
r
t
y
:
 
T
w
o
 
q
u
o
r
u
m
s
 
i
n
2
f
 
+
 
1
 
r
e
p
l
i
c
a
s
 
m
u
s
t
 
i
n
t
e
r
s
e
c
t
 
a
t
 
a
t
 
l
e
a
s
t
 
o
n
e
 
r
e
p
l
i
c
a
 
19
19
 
P
r
i
n
c
i
p
l
e
:
 
Q
u
o
r
u
m
s
 
(
f
 
=
 
1
)
 
et cetera...
 
 
N
o
r
m
a
l
 
O
p
e
r
a
t
i
o
n
:
 
Q
u
o
r
u
m
 
t
h
a
t
 
p
r
o
c
e
s
s
e
s
 
o
n
e
 
r
e
q
u
e
s
t
:
 
Q
1
.
.
.
a
n
d
 
2
n
d
 
r
e
q
u
e
s
t
:
 
Q
2
 
Q
1
 
 
Q
2
 
h
a
s
 
a
t
 
l
e
a
s
t
 
o
n
e
 
r
e
p
l
i
c
a
 
S
e
c
o
n
d
 
r
e
q
u
e
s
t
 
r
e
a
d
s
 
f
i
r
s
t
 
r
e
q
u
e
s
t
s
 
e
f
f
e
c
t
s
 
20
20
 
A
p
p
l
y
i
n
g
 
t
h
e
 
q
u
o
r
u
m
 
p
r
i
n
c
i
p
l
e
 
 
V
i
e
w
 
C
h
a
n
g
e
:
 
Q
u
o
r
u
m
 
p
r
o
c
e
s
s
e
s
 
p
r
e
v
i
o
u
s
 
(
c
o
m
m
i
t
t
e
d
)
 
r
e
q
u
e
s
t
:
 
Q
1
.
.
.
a
n
d
 
t
h
a
t
 
p
r
o
c
e
s
s
e
s
 
S
t
a
r
t
-
V
i
e
w
-
C
h
a
n
g
e
:
 
Q
2
 
Q
1
 
 
Q
2
 
h
a
s
 
a
t
 
l
e
a
s
t
 
o
n
e
 
r
e
p
l
i
c
a
 
V
i
e
w
 
C
h
a
n
g
e
 
c
o
n
t
a
i
n
s
 
c
o
m
m
i
t
t
e
d
 
r
e
q
u
e
s
t
 
21
21
 
A
p
p
l
y
i
n
g
 
t
h
e
 
q
u
o
r
u
m
 
p
r
i
n
c
i
p
l
e
W
h
a
t
s
 
u
n
d
e
s
i
r
a
b
l
e
 
a
b
o
u
t
 
t
h
i
s
 
s
e
q
u
e
n
c
e
 
o
f
 
e
v
e
n
t
s
?
 
W
h
y
 
w
o
n
t
 
t
h
i
s
 
e
v
e
r
 
h
a
p
p
e
n
?
 
 
W
h
a
t
 
h
a
p
p
e
n
s
 
i
n
s
t
e
a
d
?
22
22
S
p
l
i
t
 
B
r
a
i
n
C
l
i
e
n
t
 
1
A
 
(
P
r
i
m
a
r
y
)
C
 
N
e
t
w
o
r
k
 
p
a
r
t
i
t
i
o
n
C
l
i
e
n
t
 
2
(
n
o
t
 
a
l
l
 
p
r
o
t
o
c
o
l
 
m
e
s
s
a
g
e
s
 
s
h
o
w
n
)
R
e
q
u
e
s
t
R
e
q
u
e
s
t
B
(
N
e
w
 
P
r
i
m
a
r
y
)
 
1.
More primary-backup replication
 
2.
V
i
e
w
 
c
h
a
n
g
e
s
With Viewstamped Replication
U
s
i
n
g
 
a
 
V
i
e
w
 
S
e
r
v
e
r
 
3.
Reconfiguration
 
23
23
 
T
o
d
a
y
 
 
A
 
s
i
n
g
l
e
 
V
i
e
w
 
S
e
r
v
e
r
 
c
o
u
l
d
 
d
e
c
i
d
e
 
w
h
o
 
i
s
 
p
r
i
m
a
r
y
Clients and servers depend on view server
Don’t decide on their own (might not agree)
 
 
Goal in designing the VS:
O
n
l
y
 
o
n
e
 
p
r
i
m
a
r
y
 
a
t
 
a
 
t
i
m
e
 
f
o
r
 
c
o
r
r
e
c
t
 
s
t
a
t
e
m
a
c
h
i
n
e
 
r
e
p
l
i
c
a
t
i
o
n
 
24
24
 
W
o
u
l
d
 
c
e
n
t
r
a
l
i
z
a
t
i
o
n
 
s
i
m
p
l
i
f
y
 
d
e
s
i
g
n
?
 
F
o
r
 
n
o
w
,
 
a
s
s
u
m
e
 
V
S
 
n
e
v
e
r
 
f
a
i
l
s
 
 
E
a
c
h
 
r
e
p
l
i
c
a
 
n
o
w
 
p
e
r
i
o
d
i
c
a
l
l
y
 
p
i
n
g
s
 
t
h
e
 
V
S
V
S
 
d
e
c
l
a
r
e
s
 
r
e
p
l
i
c
a
 
d
e
a
d
 
i
f
 
m
i
s
s
e
d
 
N
 
p
i
n
g
s
 
i
n
 
a
 
r
o
w
C
o
n
s
i
d
e
r
s
 
r
e
p
l
i
c
a
 
a
l
i
v
e
 
a
f
t
e
r
 
a
 
s
i
n
g
l
e
 
p
i
n
g
 
r
e
c
e
i
v
e
d
 
 
P
r
o
b
l
e
m
:
 
R
e
p
l
i
c
a
 
c
a
n
 
b
e
 
a
l
i
v
e
 
b
u
t
 
b
e
c
a
u
s
e
 
o
f
n
e
t
w
o
r
k
 
c
o
n
n
e
c
t
i
v
i
t
y
,
 
b
e
 
d
e
c
l
a
r
e
d
 
d
e
a
d
 
25
25
 
V
i
e
w
 
S
e
r
v
e
r
 
p
r
o
t
o
c
o
l
 
o
p
e
r
a
t
i
o
n
26
26
V
i
e
w
 
S
e
r
v
e
r
:
 
S
p
l
i
t
 
B
r
a
i
n
S
1
 
(1, S
1
, S
2
)
 
(2, S
2
, −)
S
2
V
i
e
w
 
S
e
r
v
e
r
(
1
,
 
S
1
,
 
S
2
)
(
2
,
 
S
2
,
 
)
27
27
O
n
e
 
p
o
s
s
i
b
i
l
i
t
y
:
 
S
2
 
i
n
 
o
l
d
 
v
i
e
w
S
1
(1, S
1
, S
2
)
(
2
,
 
S
2
,
 
)
S
2
V
i
e
w
 
S
e
r
v
e
r
(
1
,
 
S
1
,
 
S
2
)
(
1
,
 
S
1
,
 
S
2
)
(
1
,
 
S
1
,
 
S
2
)
(
2
,
 
S
2
,
 
)
(
2
,
 
S
2
,
 
)
28
28
A
l
s
o
 
p
o
s
s
i
b
l
e
:
 
S
2
 
i
n
 
n
e
w
 
v
i
e
w
S
1
(1, S
1
, S
2
)
(
2
,
 
S
2
,
 
)
S
2
V
i
e
w
 
S
e
r
v
e
r
(
1
,
 
S
1
,
 
S
2
)
(
1
,
 
S
1
,
 
S
2
)
(
2
,
 
S
2
,
 
)
(
2
,
 
S
2
,
 
)
 
 
T
a
k
e
-
a
w
a
y
 
p
o
i
n
t
s
:
 
S
p
l
i
t
 
B
r
a
i
n
 
p
r
o
b
l
e
m
 
c
a
n
 
b
e
 
a
v
o
i
d
e
d
 
b
o
t
h
:
I
n
 
a
 
d
e
c
e
n
t
r
a
l
i
z
e
d
 
d
e
s
i
g
n
 
(
V
R
)
W
i
t
h
 
c
e
n
t
r
a
l
i
z
e
d
 
c
o
n
t
r
o
l
 
(
V
S
)
 
B
u
t
 
p
r
o
t
o
c
o
l
 
m
u
s
t
 
b
e
 
d
e
s
i
g
n
e
d
 
c
a
r
e
f
u
l
l
y
 
s
o
 
t
h
a
t
r
e
p
l
i
c
a
 
s
t
a
t
e
 
d
o
e
s
 
n
o
t
 
d
i
v
e
r
g
e
 
29
29
 
S
p
l
i
t
 
B
r
a
i
n
 
a
n
d
 
v
i
e
w
 
c
h
a
n
g
e
s
 
1.
More primary-backup replication
 
2.
View changes
 
3.
R
e
c
o
n
f
i
g
u
r
a
t
i
o
n
 
30
30
 
T
o
d
a
y
 
W
h
a
t
 
i
f
 
w
e
 
w
a
n
t
 
t
o
 
r
e
p
l
a
c
e
 
a
 
f
a
u
l
t
y
 
r
e
p
l
i
c
a
 
w
i
t
h
 
a
d
i
f
f
e
r
e
n
t
 
m
a
c
h
i
n
e
?
F
o
r
 
e
x
a
m
p
l
e
,
 
o
n
e
 
o
f
 
t
h
e
 
b
a
c
k
u
p
s
 
m
a
y
 
f
a
i
l
 
 
W
h
a
t
 
i
f
 
w
e
 
w
a
n
t
 
t
o
 
c
h
a
n
g
e
 
t
h
e
 
r
e
p
l
i
c
a
 
g
r
o
u
p
 
s
i
z
e
?
D
e
c
o
m
m
i
s
s
i
o
n
 
a
 
r
e
p
l
i
c
a
A
d
d
 
a
n
o
t
h
e
r
 
r
e
p
l
i
c
a
 
(
i
n
c
r
e
a
s
e
 
f
,
 
p
o
s
s
i
b
l
y
)
 
31
31
T
h
e
 
n
e
e
d
 
f
o
r
 
r
e
c
o
n
f
i
g
u
r
a
t
i
o
n
P
r
o
t
o
c
o
l
 
t
h
a
t
 
h
a
n
d
l
e
s
 
t
h
e
s
e
 
p
o
s
s
i
b
i
l
i
t
i
e
s
 
i
s
 
c
a
l
l
e
d
 
t
h
e
r
e
c
o
n
f
i
g
u
r
a
t
i
o
n
 
p
r
o
t
o
c
o
l
 
1.
c
o
n
f
i
g
u
r
a
t
i
o
n
:
 
s
o
r
t
e
d
 
i
d
e
n
t
i
t
i
e
s
 
o
f
 
a
l
l
 
2
f
 
+
 
1
 
r
e
p
l
i
c
a
s
 
2.
I
n
-
m
e
m
o
r
y
 
l
o
g
 
w
i
t
h
 
c
l
i
e
n
t
s
 
r
e
q
u
e
s
t
s
 
i
n
 
a
s
s
i
g
n
e
d
 
o
r
d
e
r
 
3.
v
i
e
w
-
n
u
m
b
e
r
:
 
i
d
e
n
t
i
f
i
e
s
 
p
r
i
m
a
r
y
 
i
n
 
c
o
n
f
i
g
u
r
a
t
i
o
n
 
l
i
s
t
 
4.
s
t
a
t
u
s
:
 
n
o
r
m
a
l
 
o
r
 
i
n
 
a
 
v
i
e
w
-
c
h
a
n
g
e
 
5.
e
p
o
c
h
-
n
u
m
b
e
r
:
 
i
n
d
e
x
e
s
 
c
o
n
f
i
g
u
r
a
t
i
o
n
s
 
32
32
 
R
e
p
l
i
c
a
 
s
t
a
t
e
 
(
f
o
r
 
r
e
c
o
n
f
i
g
u
r
a
t
i
o
n
)
 
P
r
i
m
a
r
y
 
i
m
m
e
d
i
a
t
e
l
y
 
s
t
o
p
s
 
a
c
c
e
p
t
i
n
g
 
n
e
w
 
r
e
q
u
e
s
t
s
33
33
R
e
c
o
n
f
i
g
u
r
a
t
i
o
n
 
(
1
)
C
l
i
e
n
t
A
 
(
P
r
i
m
a
r
y
)
B
C
 
(
r
e
m
o
v
e
)
T
i
m
e
 
R
e
c
o
n
f
i
g
u
r
a
t
i
o
n
n
e
w
-
c
o
n
f
i
g
D
 
(
a
d
d
)
(
f
 
=
 
1
)
 
P
r
i
m
a
r
y
 
i
m
m
e
d
i
a
t
e
l
y
 
s
t
o
p
s
 
a
c
c
e
p
t
i
n
g
 
n
e
w
 
r
e
q
u
e
s
t
s
 
N
o
 
u
p
-
c
a
l
l
 
t
o
 
R
S
M
 
f
o
r
 
e
x
e
c
u
t
i
n
g
 
t
h
i
s
 
r
e
q
u
e
s
t
34
34
R
e
c
o
n
f
i
g
u
r
a
t
i
o
n
 
(
2
)
C
l
i
e
n
t
A
 
(
P
r
i
m
a
r
y
)
B
C
 
(
r
e
m
o
v
e
)
T
i
m
e
 
R
e
c
o
n
f
i
g
u
r
a
t
i
o
n
n
e
w
-
c
o
n
f
i
g
D
 
(
a
d
d
)
P
r
e
p
a
r
e
,
P
r
e
p
a
r
e
O
K
(
f
 
=
 
1
)
 
P
r
i
m
a
r
y
 
s
e
n
d
s
 
C
o
m
m
i
t
 
m
e
s
s
a
g
e
s
 
t
o
 
o
l
d
 
r
e
p
l
i
c
a
s
 
P
r
i
m
a
r
y
 
s
e
n
d
s
 
S
t
a
r
t
E
p
o
c
h
 
m
e
s
s
a
g
e
 
t
o
 
n
e
w
 
r
e
p
l
i
c
a
(
s
)
35
35
R
e
c
o
n
f
i
g
u
r
a
t
i
o
n
 
(
3
)
C
l
i
e
n
t
A
 
(
P
r
i
m
a
r
y
)
B
C
 
(
r
e
m
o
v
e
)
T
i
m
e
 
R
e
c
o
n
f
i
g
u
r
a
t
i
o
n
n
e
w
-
c
o
n
f
i
g
D
 
(
a
d
d
)
P
r
e
p
a
r
e
,
P
r
e
p
a
r
e
O
K
C
o
m
m
i
t
(
f
 
=
 
1
)
 
1.
U
p
d
a
t
e
 
s
t
a
t
e
 
w
i
t
h
 
n
e
w
 
e
p
o
c
h
-
n
u
m
b
e
r
2.
Fetch state from old replicas, update log
3.
S
e
n
d
 
E
p
o
c
h
S
t
a
r
t
e
d
 
m
s
g
s
 
t
o
 
r
e
p
l
i
c
a
s
 
b
e
i
n
g
 
r
e
m
o
v
e
d
36
36
R
e
c
o
n
f
i
g
u
r
a
t
i
o
n
 
i
n
 
n
e
w
 
g
r
o
u
p
 
{
A
,
 
B
,
 
D
}
C
l
i
e
n
t
A
 
(
P
r
i
m
a
r
y
)
B
C
 
(
r
e
m
o
v
e
)
T
i
m
e
 
R
e
c
o
n
f
i
g
u
r
a
t
i
o
n
n
e
w
-
c
o
n
f
i
g
D
 
(
a
d
d
)
P
r
e
p
a
r
e
,
P
r
e
p
a
r
e
O
K
C
o
m
m
i
t
 
1.
Respond to state transfer requests from others
W
a
i
t
s
 
u
n
t
i
l
 
i
t
 
r
e
c
e
i
v
e
s
 
f
 
+
 
1
 
E
p
o
c
h
S
t
a
r
t
e
d
 
m
s
g
s
,
 
f
 
i
s
 
f
a
u
l
t
 
t
o
l
e
r
a
n
c
e
 
o
f
n
e
w
 
e
p
o
c
h
2.
S
e
n
d
 
S
t
a
r
t
E
p
o
c
h
 
m
e
s
s
a
g
e
s
 
t
o
 
n
e
w
 
r
e
p
l
i
c
a
s
 
i
f
 
t
h
e
y
 
d
o
n
t
 
h
e
a
r
E
p
o
c
h
S
t
a
r
t
e
d
 
(
n
o
t
 
s
h
o
w
n
 
a
b
o
v
e
)
 
37
37
 
R
e
c
o
n
f
i
g
u
r
a
t
i
o
n
 
a
t
 
r
e
p
l
a
c
e
d
 
r
e
p
l
i
c
a
s
 
{
C
}
 
C
l
i
e
n
t
 
A
 
(
P
r
i
m
a
r
y
)
 
B
 
C
 
(
r
e
m
o
v
e
)
 
T
i
m
e
 
 
R
e
c
o
n
f
i
g
u
r
a
t
i
o
n
 
n
e
w
-
c
o
n
f
i
g
 
D
 
(
a
d
d
)
P
r
e
p
a
r
e
,
P
r
e
p
a
r
e
O
K
 
E
p
o
c
h
S
t
a
r
t
e
d
 
C
o
m
m
i
t
 
I
f
 
a
d
m
i
n
 
d
o
e
s
n
t
 
w
a
i
t
 
f
o
r
 
r
e
c
o
n
f
i
g
u
r
a
t
i
o
n
 
t
o
 
c
o
m
p
l
e
t
e
,
m
a
y
 
c
a
u
s
e
 
>
 
f
 
f
a
i
l
u
r
e
s
 
i
n
 
o
l
d
 
g
r
o
u
p
Can’t shut down replicas on receiving Reply at client
 
Must ensure committed requests survive
reconfiguration!
 
F
i
x
:
 
A
 
n
e
w
 
t
y
p
e
 
o
f
 
r
e
q
u
e
s
t
 
C
h
e
c
k
E
p
o
c
h
 
r
e
p
o
r
t
s
 
t
h
e
c
u
r
r
e
n
t
 
e
p
o
c
h
Goes thru normal request processing (no up-call)
Return indicates reconfiguration is complete
38
38
S
h
u
t
t
i
n
g
 
d
o
w
n
 
o
l
d
 
r
e
p
l
i
c
a
s
 
V
i
e
w
s
t
a
m
p
e
d
 
R
e
p
l
i
c
a
t
i
o
n
 
i
s
 
a
 
s
t
a
t
e
 
m
a
c
h
i
n
e
r
e
p
l
i
c
a
t
i
o
n
 
p
r
o
t
o
c
o
l
 
t
h
a
t
 
t
o
l
e
r
a
t
e
s
 
f
 
c
r
a
s
h
 
f
a
i
l
u
r
e
s
 
i
n
 
a
r
e
p
l
i
c
a
 
g
r
o
u
p
 
o
f
 
2
f
 
+
 
1
 
r
e
p
l
i
c
a
s
 
The protocol uses replicated state to provide
persistence without any use of disk
 
f + 1 replicas serve as a quorum that ensures
correctness; in every step of the protocol there is at
least one replica that knows about the request
 
There’s actually sub-protocols that operate to address
distinct concerns (see next slide)
 
39
39
 
V
R
:
 
T
a
k
e
-
a
w
a
y
 
i
d
e
a
s
 
B
a
c
k
u
p
s
 
f
a
i
l
 
o
r
 
h
a
s
 
n
e
t
w
o
r
k
 
c
o
n
n
e
c
t
i
v
i
t
y
 
p
r
o
b
l
e
m
s
?
Minority partitioned from primary?
Q
u
o
r
u
m
s
 
a
l
l
o
w
 
p
r
i
m
a
r
y
 
t
o
 
c
o
n
t
i
n
u
e
 
P
r
i
m
a
r
y
 
f
a
i
l
s
 
o
r
 
h
a
s
 
n
e
t
w
o
r
k
 
c
o
n
n
e
c
t
i
v
i
t
y
 
p
r
o
b
l
e
m
s
?
Majority partitioned from primary?
R
a
p
i
d
l
y
 
e
x
e
c
u
t
e
 
v
i
e
w
 
c
h
a
n
g
e
 
R
e
p
l
i
c
a
 
p
e
r
m
a
n
e
n
t
l
y
 
f
a
i
l
s
 
o
r
 
i
s
 
r
e
m
o
v
e
d
?
R
e
p
l
i
c
a
 
a
d
d
e
d
?
 
A
d
m
i
n
i
s
t
r
a
t
o
r
 
i
n
i
t
i
a
t
e
s
 
r
e
c
o
n
f
i
g
u
r
a
t
i
o
n
 
p
r
o
t
o
c
o
l
 
40
40
 
W
h
a
t
s
 
u
s
e
f
u
l
 
w
h
e
n
Slide Note
Embed
Share

Introduction to replica management in computing systems and concurrency, covering primary-backup replication, transitioning from two to many replicas, and exploring Viewstamped Replication for increased fault tolerance and scalability. The concept of Replica state and Normal operation scenarios are also discussed.


Uploaded on Sep 07, 2024 | 0 Views


Download Presentation

Please find below an Image/Link to download the presentation.

The content on the website is provided AS IS for your information and personal use only. It may not be sold, licensed, or shared on other websites without obtaining consent from the author. Download presentation by click this link. If you encounter any issues during the download, it is possible that the publisher has removed the file from their server.

E N D

Presentation Transcript


  1. View Change Protocols and Reconfiguration CS 240: Computing Systems and Concurrency Lecture 11 Marco Canini

  2. Today 1. More primary-backup replication 2. View changes 3. Reconfiguration 2

  3. Review: primary-backup replication Nominate one replica primary Clients send all requests to primary Primary ordersclients requests Clients shl Logging Module State Machine Logging Module State Machine Servers Log Log add jmp mov shl add jmp mov shl 3

  4. From two to many replicas Clients shl Logging Module State Machine Logging Module State Machine Logging Module State Machine Servers Log Log Log add jmp mov shl add jmp mov shl add jmp mov shl Primary-Backup with many replicas Primary waits for acknowledgement from all backups All updates to set of replicas needs to update shared disk (recall VM-FT) 4

  5. What else can we do with more replicas? Viewstamped Replication: State Machine Replication for any number of replicas Replica group: Group of 2f + 1 replicas Protocol can tolerate f replica crashes Differences with primary-backup No shared disk (no reliable failure detection) Don t need to wait for all replicas to reply Need more replicas to handle f failures (2f+1 vs f+1) 5

  6. With multiple replicas, dont need to wait for all Viewstamped Replication: State Machine Replication for any number of replicas Replica group: Group of 2f + 1 replicas Protocol can tolerate f replica crashes Assumptions: 1. Handles crash failures only: Replicas fail only by completely stopping 2. Unreliable network: Messages might be lost, duplicated, delayed, or delivered out-of-order 6

  7. Replica state 1. configuration: identities of all 2f + 1 replicas 2. In-memory logwith clients requests in assigned order op1, args1 op2, args2 op3, args3 op4, args4 ... 7

  8. Normal operation (f = 1) Reply Request Prepare PrepareOK Client Execute A (Primary) B C Time 1. Primary adds request to end of its log 2. Replicas add requests to their logs in primary s log order 3. Primary waits for fPrepareOKs request is committed Makes up-call to execute the operation 8

  9. Normal operation: Key points (f = 1) Reply Request Prepare PrepareOK Client Execute A (Primary) B C Time Protocol guarantees state machine replication On execute, primary knows request in f+ 1 = 2 nodes logs Even if f = 1 then crash, 1 retains request in log 9

  10. Piggybacked commits (f = 1) Reply Request Prepare PrepareOK Client +Commit previous Execute A (Primary) B C Commit Time Previous Request s commit piggybacked on current Prepare No client Request after a timeout period? Primary sends Commit message to all backup replicas 10

  11. The need for a view change So far: Works for f failed backup replicas But what if the f failures include a failed primary? All clients requests go to the failed primary System halts despite merely f failures 11

  12. Today 1. More primary-backup replication 2. View changes With Viewstamped Replication Using a View Server 3. Reconfiguration 12

  13. Views Let different replicas assume role of primary over time System moves through a sequence of views View = (view number, primary id, backup id, ...) P View #3, #6, P View #1, #4, P View #2, #5, 13

  14. View change protocol Backup replicas monitor primary If primary seems faulty (no Prepare/Commit): Backups execute the view change protocol to select new primary View changes execute automatically, rapidly Need to keep clients and replicas in sync: same local state of the current view Same local state at clients Same local state at replicas 14

  15. Making the view change correct View changes happen locally at each replica Old primary executes requests in the old view, new primary executes requests in the new view Want to ensure state machine replication So correctness condition: Committed requests 1. Survive in the new view 2. Retain the same order in the new view 15

  16. Replica state (for view change) 1. configuration:sorted identities of all 2f + 1 replicas 2. In-memory logwith clients requests in assigned order 3. view-number: identifies primary in configuration list 4. status:normal or in a view-change 16

  17. View change protocol (f = 1) Start-View- Change Do-View- Change Start- View (!) ++view # B (New Primary) view # log log C Time 1. B notices A has failed, sends Start-View-Change 2. C replies Do-View-Change to new primary, with its log 3. B waits for f replies, then sends Start-View 4. On receipt of Start-View, C replays log, accepts new ops 17

  18. View change protocol: Correctness (f = 1) Execute A (Old Primary) Start-View- Change Do-View- Change Start- View B (New Primary) view # log log C PrepareOK Time Executed request, previous view Old primary A must have received one or two PrepareOK replies for that request (why?) Request is in B s or C s log (or both): so it will survive into new view 18

  19. Principle: Quorums (f = 1) et cetera... Any group of f + 1 replicas is called a quorum Quorum intersection property: Two quorums in 2f + 1 replicas must intersect at at least one replica 19

  20. Applying the quorum principle Normal Operation: Quorum that processes one request: Q1 ...and 2nd request: Q2 Q1 Q2 has at least one replica Second request reads first request s effects 20

  21. Applying the quorum principle View Change: Quorum processes previous (committed) request: Q1 ...and that processes Start-View-Change:Q2 Q1 Q2 has at least one replica View Change contains committed request 21

  22. Split Brain (not all protocol messages shown) Request Request Client 1 Execute Execute A (Primary) Network partition Execute Execute B (New Primary) Start-View Start-VC C Request Request Client 2 What s undesirable about this sequence of events? Why won t this ever happen? What happens instead? 22

  23. Today 1. More primary-backup replication 2. View changes With Viewstamped Replication Using a View Server 3. Reconfiguration 23

  24. Would centralization simplify design? A single View Server could decide who is primary Clients and servers depend on view server Don t decide on their own (might not agree) Goal in designing the VS: Only one primary at a time for correct state machine replication 24

  25. View Server protocol operation For now, assume VS never fails Each replica now periodically pings the VS VS declares replica dead if missed N pings in a row Considers replica alive after a single ping received Problem: Replica can be alive but because of network connectivity, be declared dead 25

  26. View Server: Split Brain (1, S1, S2) S1 View Server S2 (1, S1, S2) (2, S2, ) (2, S2, ) Client 26

  27. One possibility: S2 in old view (1, S1, S2) S1 View Server S2 (1, S1, S2) (2, S2, ) (1, S1, S2) (2, S2, ) (1, S1, S2) (2, S2, ) Client 27

  28. Also possible: S2 in new view (1, S1, S2) S1 View Server S2 (1, S1, S2) (2, S2, ) (1, S1, S2) (2, S2, ) (2, S2, ) Client 28

  29. Split Brain and view changes Take-away points: Split Brain problem can be avoided both: In a decentralized design (VR) With centralized control (VS) But protocol must be designed carefully so that replica state does not diverge 29

  30. Today 1. More primary-backup replication 2. View changes 3. Reconfiguration 30

  31. The need for reconfiguration What if we want to replace a faulty replica with a different machine? For example, one of the backups may fail What if we want to change the replica group size? Decommission a replica Add another replica (increase f, possibly) Protocol that handles these possibilities is called the reconfiguration protocol 31

  32. Replica state (for reconfiguration) 1. configuration:sorted identities of all 2f + 1 replicas 2. In-memory logwith clients requests in assigned order 3. view-number: identifies primary in configuration list 4. status:normal or in a view-change 5. epoch-number:indexes configurations 32

  33. Reconfiguration (1) (f = 1) Prepare PrepareOK Reconfiguration Client new-config A (Primary) B C (remove) D (add) Time Primary immediately stops accepting new requests 33

  34. Reconfiguration (2) (f = 1) Reply Reconfiguration Client new-config PrepareOK A (Primary) Prepare, B C (remove) D (add) Time Primary immediately stops accepting new requests No up-callto RSM for executing this request 34

  35. Reconfiguration (3) (f = 1) Reply Reconfiguration Client new-config StartEpoch PrepareOK A (Primary) Prepare, B Commit C (remove) D (add) Time Primary sends Commit messages to old replicas Primary sends StartEpoch message to new replica(s) 35

  36. Reconfiguration in new group {A, B, D} Reply Reconfiguration EpochStarted Client new-config StartEpoch PrepareOK A (Primary) Prepare, B Commit C (remove) D (add) Time 1. Update state with new epoch-number 2. Fetch state from old replicas, update log 3. Send EpochStarted msgs to replicas being removed 36

  37. Reconfiguration at replaced replicas {C} Reply Reconfiguration EpochStarted Client new-config StartEpoch PrepareOK A (Primary) Prepare, B Commit C (remove) D (add) Time 1. Respond to state transfer requests from others Waits until it receives f + 1 EpochStarted msgs, f is fault tolerance of new epoch Send StartEpoch messages to new replicas if they don t hear EpochStarted (not shown above) 2. 37

  38. Shutting down old replicas If admin doesn t wait for reconfiguration to complete, may cause > f failures in old group Can t shut down replicas on receiving Reply at client Must ensure committed requests survive reconfiguration! Fix: A new type of request CheckEpoch reports the current epoch Goes thru normal request processing (no up-call) Return indicates reconfiguration is complete 38

  39. VR: Take-away ideas Viewstamped Replication is a state machine replication protocol that tolerates f crash failures in a replica group of 2f + 1 replicas The protocol uses replicated state to provide persistence without any use of disk f + 1 replicas serve as a quorum that ensures correctness; in every step of the protocol there is at least one replica that knows about the request There s actually sub-protocols that operate to address distinct concerns (see next slide) 39

  40. Whats useful when Backups fail or has network connectivity problems? Minority partitioned from primary? Quorums allow primary to continue Primary fails or has network connectivity problems? Majority partitioned from primary? Rapidly execute view change Replica permanently fails or is removed? Replica added? Administrator initiates reconfiguration protocol 40

More Related Content

giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#giItT1WQy@!-/#