SlideShare une entreprise Scribd logo
1  sur  43
Télécharger pour lire hors ligne
RAFT Paxos
Concept
Replicated Log for
Replicated State Machine
Consensus Algorithm
Leader Election
Key (First elected leader,
then normal operation)
Optional (A form of
operation)
Log maintenance
Leader’s Log is replicated to
all Followers
Node may log
consensus operation,
but it may have holes
TLA+ Spec
Close to developer’s
implementation & usage
More abstract
State Space Large Small
a
b
c
d
e
f
a b c e f g
h i
g
unique
S1: 1
S2: 1
S3: 1
S1: 2
S2: 1
S3: 1
S1: 2
S2: 1
S3: 1
RequestVoteRequest
S1: 2
S2: 2
S3: 2
RequestVoteRespose
S1: 2
S2: 2
S3: 2
1
2
a
2
2
b
3
2
c
S1: 2
S2: 2
S3: 2
1
2
a
2
2
b
3
2
c
4
2
d
5
2
e
6
2
f
1
2
a
2
2
b
1
2
a
Committed
Index
S1: 2
S2: 2
S3: 2
1
2
a
2
2
b
3
2
c
4
2
d
5
2
e
6
2
f
1
2
a
2
2
b
3
2
c
1
2
a
2
2
b
3
2
c
4
2
d
Committed
Index
one server per term
persisted
AppendEntries
AppendEntries
1
2
a
2
2
b
1
2
a
2
2
b
1
2
a
2
2
a
1
2
a
2
2
b
1
2
a
2
2
b
Committed
Index
Leader S1: 2
Follower S2: 2
Follower S3: 2
Follower S4: 2
Follower S5: 2
1
2
a
2
2
b
1
2
a
2
2
b
1
2
a
2
2
a
1
2
a
2
2
b
1
2
a
2
2
b
Committed
Index
Crash S1: 2
Crash S2: 2
Follower S3: 3
Leader S4: 3
Follower S5: 3
3
3
c
4
3
d
3
3
c
4
3
d
1
2
a
2
2
b
1
2
a
2
2
b
1
2
a
2
2
a
1
2
a
2
2
b
1
2
a
2
2
b
Committed
Index
Follower S1: 4
Crash S2: 2
Crash S3: 3
Follower S4: 4
Leader S5: 4
3
3
c
4
3
d
3
3
c
4
3
d
5
4
e
6
4
f
7
4
g
1
2
a
2
2
b
1
2
a
2
2
b
1
2
a
2
2
a
1
2
a
2
2
b
1
2
a
2
2
b
Committed
Index
Follower S1: 5
Follower S2: 5
Leader S3: 5
Crash S4: 4
Crash S5: 4
3
3
c
4
3
d
3
3
c
4
3
d
5
4
e
6
4
f
7
4
g
3
5
h
3
5
h
3
5
h
4
5
i
1
2
a
2
2
b
1
2
a
2
2
b
1
2
a
2
2
a
1
2
a
2
2
b
1
2
a
2
2
b
Committed
Index
Leader S1: 6
Follower S2: 6
Crash S3: 5
Crash S4: 4
Follower S5: 6
3
3
c
4
3
d
3
3
c
4
3
d
5
4
e
6
4
f
7
4
g
3
5
h
3
5
h
3
5
h
4
5
i
4
6
j
5
6
k
6
6
l
4
6
j
1
2
a
2
2
b
1
2
a
2
2
b
1
2
a
2
2
a
1
2
a
2
2
b
1
2
a
2
2
b
Committed
Index
Crash S1: 6
Follower S2: 6
Follower S3: 5
Follower S4: 4
Follower S5: 6
3
3
c
4
3
d
3
3
c
4
3
d
5
4
e
6
4
f
7
4
g
3
5
h
3
5
h
3
5
h
4
5
i
4
6
j
5
6
k
6
6
l
4
6
j
1
2
a
2
2
b
1
2
a
2
2
b
1
2
a
2
2
a
1
2
a
2
2
b
1
2
a
2
2
b
Committed
Index
Crash S1: 6
Crash S2: 6
Follower S3: 5
Follower S4: 4
Follower S5: 6
3
3
c
4
3
d
3
3
c
4
3
d
5
4
e
6
4
f
7
4
g
3
5
h
3
5
h
3
5
h
4
5
i
4
6
j
5
6
k
6
6
l
4
6
j
1
2
a
2
2
b
1
2
a
2
2
b
1
2
a
2
2
a
1
2
a
2
2
b
1
2
a
2
2
b
Committed
Index
Crash S1: 6
Crash S2: 6
Leader S3: 8
Follower S4: 8
Follower S5: 8
3
3
c
4
3
d
3
3
c
4
3
d
5
4
e
6
4
f
7
4
g
3
5
h
3
5
h
3
5
h
4
5
i
4
6
j
5
6
k
6
6
l
4
6
j
1
2
a
2
2
b
1
2
a
2
2
b
1
2
a
2
2
a
1
2
a
2
2
b
1
2
a
2
2
b
Committed
Index
Crash S1: 6
Leader S2: 7
Follower S3: 7
Follower S4: 7
Follower S5: 7
3
3
c
4
3
d
3
3
c
4
3
d
5
4
e
6
4
f
7
4
g
3
5
h
3
5
h
3
5
h
4
5
i
4
6
j
5
6
k
6
6
l
4
6
j
5
7
m
5
7
m
1
2
a
2
2
b
3
5
h
4
6
j
5
7
m
4
6
1
2
a
2
2
b
Follower S5: 7
3
3
c
4
3
d
5
4
e
6
4
f
7
4
g
Leader S2: 7
5
7
m
1
2
a
2
2
b
3
5
h
4
6
j
5
7
m
1
2
a
2
2
b
Follower S5: 7
3
3
c
4
3
d
5
4
e
6
4
f
7
4
g
Leader S2: 7
4
6
j
3
5
5
7
m
1
2
a
2
2
b
3
5
h
4
6
j
5
7
m
1
2
a
2
2
b
Follower S5: 7
3
3
c
4
3
d
5
4
e
6
4
f
7
4
g
Leader S2: 7 4
6
j
3
5
h
2
2
5
7
m
1
2
a
2
2
b
3
5
h
4
6
j
5
7
m
1
2
a
2
2
b
Follower S5: 7
Leader S2: 7 4
6
j
3
5
h
2
2
3
5
h
4
6
j
5
7
m
unique id
S1
S2
S3
S4
S5
S3, S4, S4 can be
elected as new
Leader
S1, S2 can be elected
as old Leader
S1
S2
S3
S4
S5
Configuration
Change to 3+5
Change
configuration to 5
S1
S2
S3
S4
S5
Change
Configuration 3+5
Change
Configuration to 3
Step Down
• Server Variable
currentTerm: (persisted)
state: { Follower, Leader, Candidate}
votedFor: (persisted)
log: (persisted)
commitIndex
• Candidate Variable
votesResponded
votesGranted
• Leader Variable
nextIndex
matchIndex
1
1
x  3
2
1
y  1
3
1
y  9
4
2
x  2
5
3
x  0
6
3
y  7
7
3
x  5
8
3
x  4
Follower
Leader
Candidate
Init
Timeout,
Start election
Timeout,
New election
BecomeLeaderDiscover leader with
Higher term
Discover leader with
Higher term
Restart
RequestVote
ClientRequest
AdvanceCommitIndex
AppendEntriesHandleRequestVoteRequest
HandleRequestVoteResponse
HandleAppendEntriesRequest
HandleAppendEntriesResponse
DropStaleResponse
DuplicateMessage
DropMessage
[Dr. TLA+ Series] Raft - Jin Li
[Dr. TLA+ Series] Raft - Jin Li
[Dr. TLA+ Series] Raft - Jin Li

Contenu connexe

En vedette

AWS re:Invent 2016: Operations Automation and Infrastructure Management with ...
AWS re:Invent 2016: Operations Automation and Infrastructure Management with ...AWS re:Invent 2016: Operations Automation and Infrastructure Management with ...
AWS re:Invent 2016: Operations Automation and Infrastructure Management with ...
Amazon Web Services
 

En vedette (10)

Raft
Raft Raft
Raft
 
可靠分布式系统基础 Paxos的直观解释
可靠分布式系统基础 Paxos的直观解释可靠分布式系统基础 Paxos的直观解释
可靠分布式系统基础 Paxos的直观解释
 
AWS re:Invent 2016: Running Batch Jobs on Amazon ECS (CON310)
AWS re:Invent 2016: Running Batch Jobs on Amazon ECS (CON310)AWS re:Invent 2016: Running Batch Jobs on Amazon ECS (CON310)
AWS re:Invent 2016: Running Batch Jobs on Amazon ECS (CON310)
 
Introduction to Ethereum
Introduction to EthereumIntroduction to Ethereum
Introduction to Ethereum
 
AWS re:Invent 2016: Operations Automation and Infrastructure Management with ...
AWS re:Invent 2016: Operations Automation and Infrastructure Management with ...AWS re:Invent 2016: Operations Automation and Infrastructure Management with ...
AWS re:Invent 2016: Operations Automation and Infrastructure Management with ...
 
AWS re:Invent 2016: Running Microservices on Amazon ECS (CON309)
AWS re:Invent 2016: Running Microservices on Amazon ECS (CON309)AWS re:Invent 2016: Running Microservices on Amazon ECS (CON309)
AWS re:Invent 2016: Running Microservices on Amazon ECS (CON309)
 
AWS re:Invent 2016: Service Integration Delivery and Automation Using Amazon ...
AWS re:Invent 2016: Service Integration Delivery and Automation Using Amazon ...AWS re:Invent 2016: Service Integration Delivery and Automation Using Amazon ...
AWS re:Invent 2016: Service Integration Delivery and Automation Using Amazon ...
 
Introduction to Apache ZooKeeper
Introduction to Apache ZooKeeperIntroduction to Apache ZooKeeper
Introduction to Apache ZooKeeper
 
AWS re:Invent 2016: Deploying Scalable SAP Hybris Clusters using Docker (CON312)
AWS re:Invent 2016: Deploying Scalable SAP Hybris Clusters using Docker (CON312)AWS re:Invent 2016: Deploying Scalable SAP Hybris Clusters using Docker (CON312)
AWS re:Invent 2016: Deploying Scalable SAP Hybris Clusters using Docker (CON312)
 
cdn的那些事儿
cdn的那些事儿cdn的那些事儿
cdn的那些事儿
 

Dernier

The basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptxThe basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptx
heathfieldcps1
 

Dernier (20)

Google Gemini An AI Revolution in Education.pptx
Google Gemini An AI Revolution in Education.pptxGoogle Gemini An AI Revolution in Education.pptx
Google Gemini An AI Revolution in Education.pptx
 
COMMUNICATING NEGATIVE NEWS - APPROACHES .pptx
COMMUNICATING NEGATIVE NEWS - APPROACHES .pptxCOMMUNICATING NEGATIVE NEWS - APPROACHES .pptx
COMMUNICATING NEGATIVE NEWS - APPROACHES .pptx
 
Jamworks pilot and AI at Jisc (20/03/2024)
Jamworks pilot and AI at Jisc (20/03/2024)Jamworks pilot and AI at Jisc (20/03/2024)
Jamworks pilot and AI at Jisc (20/03/2024)
 
Kodo Millet PPT made by Ghanshyam bairwa college of Agriculture kumher bhara...
Kodo Millet  PPT made by Ghanshyam bairwa college of Agriculture kumher bhara...Kodo Millet  PPT made by Ghanshyam bairwa college of Agriculture kumher bhara...
Kodo Millet PPT made by Ghanshyam bairwa college of Agriculture kumher bhara...
 
How to setup Pycharm environment for Odoo 17.pptx
How to setup Pycharm environment for Odoo 17.pptxHow to setup Pycharm environment for Odoo 17.pptx
How to setup Pycharm environment for Odoo 17.pptx
 
Single or Multiple melodic lines structure
Single or Multiple melodic lines structureSingle or Multiple melodic lines structure
Single or Multiple melodic lines structure
 
The basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptxThe basics of sentences session 3pptx.pptx
The basics of sentences session 3pptx.pptx
 
ICT role in 21st century education and it's challenges.
ICT role in 21st century education and it's challenges.ICT role in 21st century education and it's challenges.
ICT role in 21st century education and it's challenges.
 
Basic Civil Engineering first year Notes- Chapter 4 Building.pptx
Basic Civil Engineering first year Notes- Chapter 4 Building.pptxBasic Civil Engineering first year Notes- Chapter 4 Building.pptx
Basic Civil Engineering first year Notes- Chapter 4 Building.pptx
 
Holdier Curriculum Vitae (April 2024).pdf
Holdier Curriculum Vitae (April 2024).pdfHoldier Curriculum Vitae (April 2024).pdf
Holdier Curriculum Vitae (April 2024).pdf
 
Graduate Outcomes Presentation Slides - English
Graduate Outcomes Presentation Slides - EnglishGraduate Outcomes Presentation Slides - English
Graduate Outcomes Presentation Slides - English
 
This PowerPoint helps students to consider the concept of infinity.
This PowerPoint helps students to consider the concept of infinity.This PowerPoint helps students to consider the concept of infinity.
This PowerPoint helps students to consider the concept of infinity.
 
FSB Advising Checklist - Orientation 2024
FSB Advising Checklist - Orientation 2024FSB Advising Checklist - Orientation 2024
FSB Advising Checklist - Orientation 2024
 
Towards a code of practice for AI in AT.pptx
Towards a code of practice for AI in AT.pptxTowards a code of practice for AI in AT.pptx
Towards a code of practice for AI in AT.pptx
 
HMCS Max Bernays Pre-Deployment Brief (May 2024).pptx
HMCS Max Bernays Pre-Deployment Brief (May 2024).pptxHMCS Max Bernays Pre-Deployment Brief (May 2024).pptx
HMCS Max Bernays Pre-Deployment Brief (May 2024).pptx
 
Accessible Digital Futures project (20/03/2024)
Accessible Digital Futures project (20/03/2024)Accessible Digital Futures project (20/03/2024)
Accessible Digital Futures project (20/03/2024)
 
On_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptx
On_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptxOn_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptx
On_Translating_a_Tamil_Poem_by_A_K_Ramanujan.pptx
 
80 ĐỀ THI THỬ TUYỂN SINH TIẾNG ANH VÀO 10 SỞ GD – ĐT THÀNH PHỐ HỒ CHÍ MINH NĂ...
80 ĐỀ THI THỬ TUYỂN SINH TIẾNG ANH VÀO 10 SỞ GD – ĐT THÀNH PHỐ HỒ CHÍ MINH NĂ...80 ĐỀ THI THỬ TUYỂN SINH TIẾNG ANH VÀO 10 SỞ GD – ĐT THÀNH PHỐ HỒ CHÍ MINH NĂ...
80 ĐỀ THI THỬ TUYỂN SINH TIẾNG ANH VÀO 10 SỞ GD – ĐT THÀNH PHỐ HỒ CHÍ MINH NĂ...
 
HMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptx
HMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptxHMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptx
HMCS Vancouver Pre-Deployment Brief - May 2024 (Web Version).pptx
 
REMIFENTANIL: An Ultra short acting opioid.pptx
REMIFENTANIL: An Ultra short acting opioid.pptxREMIFENTANIL: An Ultra short acting opioid.pptx
REMIFENTANIL: An Ultra short acting opioid.pptx
 

[Dr. TLA+ Series] Raft - Jin Li