Distributed systems II Fault-Tolerant Broadcast

Slides:



Advertisements
Similar presentations
1 Process groups and message ordering If processes belong to groups, certain algorithms can be used that depend on group properties membership create (
Advertisements

COS 461 Fall 1997 Group Communication u communicate to a group of processes rather than point-to-point u uses –replicated service –efficient dissemination.
CS425/CSE424/ECE428 – Distributed Systems – Fall 2011 Material derived from slides by I. Gupta, M. Harandi, J. Hou, S. Mitra, K. Nahrstedt, N. Vaidya.
DISTRIBUTED SYSTEMS II FAULT-TOLERANT BROADCAST Prof Philippas Tsigas Distributed Computing and Systems Research Group.
CSE 486/586, Spring 2014 CSE 486/586 Distributed Systems Reliable Multicast Steve Ko Computer Sciences and Engineering University at Buffalo.
CS542 Topics in Distributed Systems Diganta Goswami.
LEADER ELECTION CS Election Algorithms Many distributed algorithms need one process to act as coordinator – Doesn’t matter which process does the.
CS 582 / CMPE 481 Distributed Systems
Group Communications Group communication: one source process sending a message to a group of processes: Destination is a group rather than a single process.
Copyright © George Coulouris, Jean Dollimore, Tim Kindberg This material is made available for private study and for direct.
1 Principles of Reliable Distributed Systems Lecture 5: Failure Models, Fault-Tolerant Broadcasts and State-Machine Replication Spring 2005 Dr. Idit Keidar.
Distributed Systems Fall 2009 Replication Fall 20095DV0203 Outline Group communication Fault-tolerant services –Passive and active replication Highly.
Aran Bergman, Principles of Reliable Distributed Systems, Technion EE, Spring Principles of Reliable Distributed Systems Recitation 5: Reliable.
Lecture 12 Synchronization. EECE 411: Design of Distributed Software Applications Summary so far … A distributed system is: a collection of independent.
Logical Clocks (2). Topics r Logical clocks r Totally-Ordered Multicasting r Vector timestamps.
Computer Science 425 Distributed Systems (Fall 2009) Lecture 5 Multicast Communication Reading: Section 12.4 Klara Nahrstedt.
1 A Modular Approach to Fault-Tolerant Broadcasts and Related Problems Author: Vassos Hadzilacos and Sam Toueg Distributed Systems: 526 U1580 Professor:
Fault-Tolerant Broadcast Terminology: broadcast(m) a process broadcasts a message to the others deliver(m) a process delivers a message to itself 1.
Group Communication A group is a collection of users sharing some common interest.Group-based activities are steadily increasing. There are many types.
Group Communication Group oriented activities are steadily increasing. There are many types of groups:  Open and Closed groups  Peer-to-peer and hierarchical.
Logical Clocks. Topics Logical clocks Totally-Ordered Multicasting Vector timestamps.
Farnaz Moradi Based on slides by Andreas Larsson 2013.
1 Chapter 7: Clock Synchronization, Coordination &Agreement.
Hwajung Lee. A group is a collection of users sharing some common interest.Group-based activities are steadily increasing. There are many types of groups:
DISTRIBUTED SYSTEMS II FAULT-TOLERANT BROADCAST (CNT.) Prof Philippas Tsigas Distributed Computing and Systems Research Group.
Totally Ordered Broadcast in the face of Network Partitions [Keidar and Dolev,2000] INF5360 Student Presentation 4/3-08 Miran Damjanovic
EEC 688/788 Secure and Dependable Computing Lecture 10 Wenbing Zhao Department of Electrical and Computer Engineering Cleveland State University
Distributed systems Consensus Prof R. Guerraoui Distributed Programming Laboratory.
Exercises for Chapter 15: COORDINATION AND AGREEMENT From Coulouris, Dollimore and Kindberg Distributed Systems: Concepts and Design Edition 3, © Addison-Wesley.
Building Dependable Distributed Systems, Copyright Wenbing Zhao
SysRép / 2.5A. SchiperEté The consensus problem.
Lecture 10: Coordination and Agreement (Chap 12) Haibin Zhu, PhD. Assistant Professor Department of Computer Science Nipissing University © 2002.
DISTRIBUTED SYSTEMS II FAULT-TOLERANT BROADCAST Prof Philippas Tsigas Distributed Computing and Systems Research Group.
Fault-Tolerant Broadcast Terminology: broadcast(m) a process broadcasts a message to the others deliver(m) a process delivers a message to itself 1.
Fault Tolerance (2). Topics r Reliable Group Communication.
Group Communication A group is a collection of users sharing some common interest.Group-based activities are steadily increasing. There are many types.
EEC 688/788 Secure and Dependable Computing Lecture 10 Wenbing Zhao Department of Electrical and Computer Engineering Cleveland State University
Reliable multicast Tolerates process crashes. The additional requirements are: Only correct processes will receive multicasts from all correct processes.
Exercises for Chapter 11: COORDINATION AND AGREEMENT
Distributed Systems Course Coordination and Agreement
CSE 486/586 Distributed Systems Reliable Multicast --- 1
Coordination and Agreement
The consensus problem in distributed systems
When Is Agreement Possible
Switching Techniques In large networks there might be multiple paths linking sender and receiver. Information may be switched as it travels through various.
Coordination and Agreement
Distributed systems Total Order Broadcast
Computer Science 425 Distributed Systems CS 425 / ECE 428 Fall 2013
Alternating Bit Protocol
Distributed Consensus
CSCE 668 DISTRIBUTED ALGORITHMS AND SYSTEMS
Active replication for fault tolerance
Switching Techniques.
EEC 688/788 Secure and Dependable Computing
EEC 688/788 Secure and Dependable Computing
EEC 688/788 Secure and Dependable Computing
EEC 688/788 Secure and Dependable Computing
EEC 688/788 Secure and Dependable Computing
EEC 688/788 Secure and Dependable Computing
EEC 688/788 Secure and Dependable Computing
EEC 688/788 Secure and Dependable Computing
Lecture 9: Ordered Multicasting
EEC 688/788 Secure and Dependable Computing
Distributed Systems Course Coordination and Agreement
Distributed systems Consensus
CSE 486/586 Distributed Systems Reliable Multicast --- 2
COT 5611 Operating Systems Design Principles Spring 2014
CSE 486/586 Distributed Systems Reliable Multicast --- 1
M. Mock and E. Nett and S. Schemmer
Presentation transcript:

Distributed systems II Fault-Tolerant Broadcast Prof Philippas Tsigas Distributed Computing and Systems Research Group Distributed systems II Fault-Tolerant Broadcast

Broadcast A deliver m B m broadcast deliver C

Fault-Tolerant Broadcast Terminology: broadcast(m) a process broadcasts a message to the others deliver(m) a process delivers a message to itself 3

Broadcast abstractions P2 Best-effort broadcast Reliable broadcast Uniform broadcast … P3 P1

(B-U)Reliable broadcast Modules of a process Applications indication request (deliver) (B-U)Reliable broadcast indication (deliver) (deliver) Failure detector indication indication Channels request (deliver) request (deliver)

Synchronous vs. asynchronous Types of process failures Broadcast Models: Synchronous vs. asynchronous Types of process failures Types of communication failures Network topology Deterministic vs. randomized 6

Reliable Broadcast Three conditions Agreement: all correct processes eventually deliver same set of messages Validity: set of messages delivered by correct processes includes all messages broadcasted by correct processes Integrity: each correct process P delivers a message from correct process Q at most once, and only if Q actually broadcasted it 7

Reliable Broadcast What about faulty processes? Definition: A property is uniform if faulty processes satisfy it as well. Uniform agreement: If a process (correct or faulty) delivers m, then all correct processes eventually deliver m. Uniform integrity: For every broadcasted message m, every process (correct or not) delivers m at most once, and only if some process has broadcasted m 8

Reliable broadcast p1 p2 p3 delivery delivery crash m2 m1 m2 delivery

Uniform reliable broadcast delivery delivery p1 crash m2 m1 delivery delivery p2 crash m2 m1 delivery delivery p3

How can we implement Reliable Broadcast? Model Asynchronous Benign process and link failures only No network partitions 11

Assume we have send(m) and receive(m) primitives Reliable Broadcast Assume we have send(m) and receive(m) primitives Transmit and send messages across a link If P sends m to Q, and link correct, then Q eventually receives m For all m, Q receives m at most once from P, and only if P actually sent m 12

Reliability of one-to-one communication validity: any message in the outgoing message buffer is eventually delivered to the incoming message buffer; integrity: the message received is identical to one sent, and no messages are delivered twice. 13

How do we achieve validity and integrity? any message in the outgoing message buffer is eventually delivered to the incoming message buffer; integrity: the message received is identical to one sent, and no messages are delivered twice. validity - by use of acknowledgements and retries integrity by use checksums, reject duplicates (e.g. due to retries). If allowing for malicious users, use security techniques • 14

Reliable Broadcast R-broadcast(m) uniquely tag m with sender and sequence number send(m) to all neighbours (including self) end R-broadcast R-deliver(m) upon receive(m) do if i have not already delivered m then if I am not the sender of m then send m to all neighbours endif deliver(m) end R-deliver 15

In an asynchronous system Reliable Broadcast In an asynchronous system Where every two correct processes are connected via a path that never fails, the previous algorithm implements reliable broadcast with uniform integrity: For every broadcasted message m, every process (correct or not) delivers m at most once, and only if some process broadcast m. 16

Algorithm idea (rb) p1 crash m m p2 m delivery m p3 delivery

Prove Agreement, Validity and Integrity TODO Prove Agreement, Validity and Integrity 18

In an asynchronous system Reliable Broadcast In an asynchronous system where every two correct processes are connected via a path that never fails, and only receive omissions occur, then the algorithm satisfies uniform agreement: If a process (correct or faulty) delivers m, then all correct processes eventually deliver m. 19

Extend the previous Proof for Uniform Agreement TODO Extend the previous Proof for Uniform Agreement 20

Ordering (1) So far, we did not consider ordering among messages; In particular, we considered messages to be independent Two messages from the same process might not be delivered in the order they were broadcast

FIFO ? p1 p2 p3 delivery delivery m2 m1 delivery delivery m1 m2

All messages broadcast by same sender delivered in order sent FIFO Broadcast Same as reliable, plus All messages broadcast by same sender delivered in order sent 23

FIFO Broadcast msgBag=0 Next[Q]=1 for all processes Q F-broadcast(m) R-broadcast(m) F-deliver(m) upon R-deliver(m) do Q := sender(m) msgBag := msgBagU{m} while (ᴲ m´ in msgBag : sender(m´)=Q and seq (m´) = next[Q]) do F-deliver(m´) next[Q] := next[Q]+1 msgBag:=msqBag-{m´} endwhile 24

FIFO Broadcast Theorem 1: Given a reliable broadcast algorithm this algorithm is uniform FIFO. TODO: Prove it. Theorem 2: if the reliable broadcast algorithm satisfies uniform agreement, so does this algorithm. 25

Limitations of FIFO Broadcast Scenario: User A broadcasts a message to a mailing list/Board B delivers that article B broadcasts reply C delivers B’s response without A´s original message and misinterprets the message 26

Intuitions A message m1 that causes a message m2 might be delivered by some process after m2 Causal broadcast alleviates the need for the application to deal with such dependencies

Causality ? p1 p2 p3 delivery delivery m2 m1 delivery delivery m1 m2

Causal Broadcast prevDel is sequence of messages that P C-delivered since its last C-broadcast C-broadcast(m) F-broadcast(prevDel●m) prevDel:=Ø C-deliever(m) upon F-deliever(m1,m2,...,ml) do for i in 1..l do if P has not previously C-delivered mi then C-deliver(mi) prevDel:=prevDel●mi 29

Causal Broadcast Theorem 1: If the FIFO broadcast algorithm is Uniform FIFO, this is a uniform causal broadcast algorithm. Theorem 2: if the FIFO broadcast satisfies Uniform Agreement, so does this one. 30

Limitation of Causal Broadcast Causal broadcast does not impose any order on unrelated messages. Two correct processes can deliver operations/request in different order. 31

Total, FIFO and causal ordering of multicast messages Notice the consistent ordering of totally ordered messages T1 and T2. They are opposite to real time. The order can be arbitrary it need not be FIFO or causal Figure 11.12 and the causally related messages C1 and C3 • 32

Atomic Broadcast Requires that all correct processes deliver all messages in the same order. Implies that all correct processes see the same view of the world. 33

Atomic Broadcast Theorem: Atomic broadcast is impossible in asynchronous systems. Proof: Equivalent to consensus problem. 34

Review of Consensus 3 8 1 8 8 8 35

FLP Theorem: Consensus is impossible in any asynchronous system if one process can halt. [Fisher, Lynch, Peterson 1985] 36

Theorem 1: Any atomic broadcast algorithm solves consensus. Everybody does an Atomic Broadcast Decides first value delivered Theorem 2: Atomic broadcast is impossible in any asynchronous system if one process can halt. Proof: By contradiction using FLP and Theorem 1 37

Total ordering using a sequencer Figure 11.14 A process wishing to TO-multicast m to g attaches a unique id, id(m) and sends it to the sequencer and the members. Other processes: B-deliver <m,i> put <m,i> in hold-back queue B-deliver order message, get g and S and i from order message wait till <m,i> in queue and S = rg, TO-deliver m and set rg to S+1 Note error in book Figure in 1st impression The sequencer keeps sequence number sg for group g When it B-delivers the message it multicasts an ‘order’ message to members of g and increments sg. • 38

Consensus is solvable in: Atomic Broadcast Consensus is solvable in: Synchronous systems (we will discuss such an algorithm that works in f+1 rounds) Certain semi-synchronous systems Consensus is also solvable in Asynchronous systems with randomization Asynchronous systems with failure-detectors 39

SLIDES FROM THE BOOK TO HAVE A LOOK AT Please check aslo the slides from your book. I appened them here. 40

Distributed Systems Course Coordination and Agreement 11.4 Multicast communication this chapter covers other types of coordination and agreement such as mutual exclusion, elections and consensus. We will study only multicast. But we will study the two-phase commit protocol for transactions in Chapter 12, which is an example of consensus We also omit the discussion of failure detectors which is relevant to replication For a 1hr 15 mins lecture, the following slides were omitted: IP multicast implementation of basic multicast IP multicast implementation of reliable multicast mplementation of FIFO multicast over basic multicast ISIS algorithm for totally ordered multicast (one of these topics could have been included in the time)

Revision of IP multicast (section 4.5.1 page154) How can you restrict a multicast to the local area network? Give two reasons for restricting the scope of a multicast message IP multicast – an implementation of group communication built on top of IP (note IP packets are addressed to computers) allows the sender to transmit a single IP packet to a set of computers that form a multicast group (a class D internet address with first 4 bits 1110) Dynamic membership of groups. Can send to a group with or without joining it To multicast, send a UDP datagram with a multicast address To join, make a socket join a group (s.joinGroup(group) - Fig 4.17) enabling it to receive messages to the group Multicast routers Local messages use local multicast capability. Routers make it efficient by choosing other routers on the way. Failure model Omission failures  some but not all members may receive a message. e.g. a recipient may drop message, or a multicast router may fail IP packets may not arrive in sender order, group members can receive messages in different orders Restrict range of a multicast by setting the time to live The reasons for doing this are: 1) for efficiency 2) to prevent sending to another group elsewhere with the same address • 42

Introduction to multicast What is meant by[the term broadcast ? Many projects - Amoeba, Isis, Transis, Horus (refs p436) Multicast communication requires coordination and agreement. The aim is for members of a group to receive copies of messages sent to the group Many different delivery guarantees are possible e.g. agree on the set of messages received or on delivery ordering A process can multicast by the use of a single operation instead of a send to each member For example in IP multicast aSocket.send(aMessage) The single operation allows for: efficiency I.e. send once on each link, using hardware multicast when available, e.g. multicast from a computer in London to two in Beijing delivery guarantees e.g. can’t make a guarantee if multicast is implemented as multiple sends and the sender fails. Can also do ordering the term broadcast means delivery to all local processes • 43

System model The system consists of a collection of processes which can communicate reliably over 1-1 channels Processes fail only by crashing (no arbitrary failures) Processes are members of groups - which are the destinations of multicast messages In general process p can belong to more than one group Operations multicast(g, m) sends message m to all members of process group g deliver (m) is called to get a multicast message delivered. It is different from receive as it may be delayed to allow for ordering or reliability. Multicast message m carries the id of the sending process sender(m) and the id of the destination group group(m) We assume there is no falsification of the origin and destination of messages Will discuss reliability of 1-1 channels in a minute arbitrary failures - e.g. sending false messages such as untrue acks process p can belong to more than one group - but to simplify often restrict it to 1 • 44

Open and closed groups Does IP multicast support open and closed groups? Closed groups only members can send to group, a member delivers to itself they are useful for coordination of groups of cooperating servers Open they are useful for notification of events to groups of interested processes Figure 11.9 Yes, IP multicast does support both open and closed groups • 45

Reliability of one-to-one communication(Ch.2 page 57) How do we achieve integrity? How do we achieve validity? The term reliable 1-1 communication is defined in terms of validity and integrity as follows: validity: any message in the outgoing message buffer is eventually delivered to the incoming message buffer; integrity: the message received is identical to one sent, and no messages are delivered twice. validity - by use of acknowledgements and retries integrity by use checksums, reject duplicates (e.g. due to retries). If allowing for malicious users, use security techniques • 46

11.4.1 Basic multicast What are ack-implosions? A correct process will eventually deliver the message provided the multicaster does not crash note that IP multicast does not give this guarantee The primitives are called B-multicast and B-deliver A straightforward but ineffective method of implementation: use a reliable 1-1 send (i.e. with integrity and validity as above) To B-multicast(g,m): for each process p e g, send(p, m); On receive (m) at p: B-deliver (m) at p Problem if the number of processes is large, the protocol will suffer from ack-implosion Ack implosions - multicaster is sent acks by members and so many arrive that it may drop somne of them, so it retransmits and gets yet more acks. A practical implementation of Basic Multicast may be achieved over IP multicast (on next slide, but not shown) • 47

Implementation of basic multicast over IP Each process p maintains: a sequence number, Spg for each group it belongs to and Rqg, the sequence number of the latest message it has delivered from process q For process p to B-multicast a message m to group g it piggybacks Sgp on the message m, using IP multicast to send it the piggybacked sequence numbers allow recipients to learn about messages they have not received On receive (g,m, S) at p: if S = Rqg +1 B-deliver (m) and increment Rqg by 1 if S < Rqg +1 reject the message because it has been delivered before if S > Rqg +1 note that a message is missing, request missing message from sender. (will use a hold-back queue to be discussed later on) If the sender crashes, then a message may be delivered to some members of the group but not others. • 48

11.4.2 Reliable multicast The protocol is correct even if the multicaster crashes it satisfies criteria for validity, integrity and agreement it provides operations R-multicast and R-deliver Integrity - a correct process, p delivers m at most once. Also p e group(m) and m was supplied to a multicast operation by sender(m) Validity - if a correct process multicasts m, it will eventually deliver m Agreement - if a correct process delivers m then all correct processes in group(m) will eventually deliver m integrity as for 1-1 communication validity - simplify by choosing sender as the one process agreement - all or nothing - atomicity, even if multicaster crashes • 49

Reliable multicast algorithm over basic multicast Agreement - every correct process B-multicasts the message to the others. If p does not R-deliver then this is because it didn’t B-deliver - because no others did either. Reliable multicast algorithm over basic multicast Integrity - because the reliable 1-1 channels used for B-multicast guarantee integrity Validity - a correct process will B-deliver to itself processes can belong to several closed groups to R-multicast a message, a process B-multicasts it to processes in the group including itself Figure 11.10 when a message is B-delivered, the recipient B-multicasts it to the group, then R-delivers it. Duplicates are detected. primitives R-multicast and R-deliver Correct in an asynchronous nsystem - no timing assumptions inefficient - each message is sent |g| times Reliable multicast can be implemented efficiently over IP multicast by holding back messages until every member can receive them. We skip that. What can you say about the performance of this algorithm? Is this algorithm correct in an asynchronous system? • 50

Reliable multicast over IP multicast (page 440) This protocol assumes groups are closed. It uses: piggybacked acknowledgement messages negative acknowledgements when messages are missed Process p maintains: Spg a message sequence number for each group it belongs to and Rqg sequence number of latest message received from process q to g For process p to R-multicast message m to group g piggyback Spg and +ve acks for messages received in the form <q, Rqg > IP multicasts the message to g, increments Spg by 1 the piggybacked values in a message allow recipients to learn about messages they have not yet received A process on receipt by of a message to g with S from p Iff S=Rpg+1 R-deliver the message and increment Rpg by 1 If S≤ Rpg discard the message If S> Rpg + 1 or if R<Rqg (for enclosed ack <q,R>) then it has missed messages and requests them with negative acknowledgements puts new message in hold-back queue for later delivery the piggybacked values in a message allow recipients to learn about messages they have not yet received • 51

The hold-back queue for arriving multicast messages The hold back queue is not necessary for reliability as in the implementation using IP muilticast, but it simplifies the protocol, allowing sequence numbers to represent sets of messages. Hold-back queues are also used for ordering protocols. Figure 11.11 • 52

Reliability properties of reliable multicast over IP Integrity - duplicate messages detected and rejected. IP multicast uses checksums to reject corrupt messages Validity - due to IP multicast in which sender delivers to itself Agreement - processes can detect missing messages. They must keep copies of messages they have delivered so that they can re-transmit them to others. discarding of copies of messages that are no longer needed : when piggybacked acknowledgements arrive, note which processes have received messages. When all processes in g have the message, discard it. problem of a process that stops sending - use ‘heartbeat’ messages. This protocol has been implemented in a practical way in Psynch and Trans (refs. on p442) • 53

11.4.3 Ordered multicast The basic multicast algorithm delivers messages to processes in an arbitrary order. A variety of orderings may be implemented: FIFO ordering If a correct process issues multicast(g, m) and then multicast(g,m’ ), then every correct process that delivers m’ will deliver m before m’ . Causal ordering If multicast(g, m)  multicast(g,m’ ), where  is the happened-before relation between messages in group g, then any correct process that delivers m’ will deliver m before m’ . Total ordering If a correct process delivers message m before it delivers m’, then any other correct process that delivers m’ will deliver m before m’. Ordering is expensive in delivery latency and bandwidth consumption • 54

Total, FIFO and causal ordering of multicast messages Notice the consistent ordering of totally ordered messages T1 and T2. They are opposite to real time. The order can be arbitrary it need not be FIFO or causal Figure 11.12 Ordered multicast delivery is expensive in bandwidth and latency. Therefore the less expensive orderings (e.g. FIFO or causal) are chosen for applications for which they are suitable Note the FIFO-related messages F1 and F2 and the causally related messages C1 and C3 these definitions do not imply reliability, but we can define atomic multicast - reliable and totally ordered. • 55

Display from a bulletin board program Users run bulletin board applications which multicast messages One multicast group per topic (e.g. os.interesting) Require reliable multicast - so that all members receive messages Ordering: total (makes the numbers the same at all sites) Bulletin board: os.interesting Item From Subject 23 A.Hanlon Mach 24 G.Joseph Microkernels 25 Re: Microkernels 26 T.L’Heureux RPC performance 27 M.Walker Re: Mach end Figure 11.13 causal (makes replies come after original message) FIFO (gives sender order • 56

Implementation of FIFO ordering over basic multicast We discuss FIFO ordered multicast with operations FO-multicast and FO-deliver for non-overlapping groups. It can be implemented on top of any basic multicast Each process p holds: Spg a count of messages sent by p to g and Rqg the sequence number of the latest message to g that p delivered from q For p to FO-multicast a message to g, it piggybacks Spg on the message, B-multicasts it and increments Spg by 1 On receipt of a message from q with sequence number S, p checks whether S = Rqg + 1. If so, it FO-delivers it. if S > Rqg + 1 then p places message in hold-back queue until intervening messages have been delivered. (note that B-multicast does eventually deliver messages unless the sender crashes) • 57

Implementation of totally ordered multicast The general approach is to attach totally ordered identifiers to multicast messages each receiving process makes ordering decisions based on the identifiers similar to the FIFO algorithm, but processes keep group specific sequence numbers operations TO-multicast and TO-deliver we present two approaches to implementing total ordered multicast over basic multicast using a sequencer (only for non-overlapping groups) the processes in a group collectively agree on a sequence number for each message • 58

Total ordering using a sequencer Figure 11.14 A process wishing to TO-multicast m to g attaches a unique id, id(m) and sends it to the sequencer and the members. Other processes: B-deliver <m,i> put <m,i> in hold-back queue B-deliver order message, get g and S and i from order message wait till <m,i> in queue and S = rg, TO-deliver m and set rg to S+1 Note error in book Figure in 1st impression The sequencer keeps sequence number sg for group g When it B-delivers the message it multicasts an ‘order’ message to members of g and increments sg. • 59

Discussion of sequencer protocol What can the sequencer do about its history buffer becoming full? What happens when some member stops multicasting? Members that do not multicast send heartbeat messages (with a sequence number) Members piggyback on their messages the latest sequence number they have seen Since sequence numbers are defined by a sequencer, we have total ordering. Like B-multicast, if the sender does not crash, all members receive the message What are the potential problems with using a single sequencer? Kaashoek’s protocol uses hardware-based multicast The sender transmits one message to sequencer, then the sequencer multicasts the sequence number and the message but IP multicast is not as reliable as B-multicast so the sequencer stores messages in its history buffer for retransmission on request members notice messages are missing by inspecting sequence numbers the ordering is also FIFO because the sender’s messages arrive in order at sequencer it is not causal a sequencer may become bottleneck a sequencer is a critical point of failure can improve this by storing message at f+ 1 nodes before delivering, so as to tolerate up to f failures Members inform it as to the latest sequence number they have seen (piggybacked) If a member stops multicasting, the sequencer will not know what they have received. To solve this problem, members send 'heartbeat messages' containing sequnce numbers • 60

The ISIS algorithm for total ordering this protocol is for open or closed groups 2 1 1 Message 2 Proposed Seq P 3 4 3 Agreed Seq Figure 11.15 1. the process P1 B-multicasts a message to members of the group 2. the receiving processes propose numbers and return them to the sender process B-multicasts a message to members of the group receiving processes propose numbers and return them to the sender sender uses proposed numbers to generate agreed numbers 3. the sender uses the proposed numbers to generate an agreed number • 61

ISIS total ordering - agreement of sequence numbers Each process, q keeps: Aqg the largest agreed sequence number it has seen and Pqg its own largest proposed sequence number 1. Process p B-multicasts <m, i> to g, where i is a unique identifier for m. 2. Each process q replies to the sender p with a proposal for the message’s agreed sequence number of Pqg := Max(Aqg, Pqg ) + 1. assigns the proposed sequence number to the message and places it in its hold-back queue 3. p collects all the proposed sequence numbers and selects the largest as the next agreed sequence number, a. It B-multicasts <i, a> to g. Recipients set Aqg := Max(Aqg, a ) , attach a to the message and re-order hold-back queue. • 62

Discussion of ordering in ISIS protocol Hold-back queue ordered with the message with the smallest sequence number at the front of the queue when the agreed number is added to a message, the queue is re-ordered when the message at the front has an agreed id, it is transferred to the delivery queue even if agreed, those not at the front of the queue are not transferred every process agrees on the same order and delivers messages in that order, therefore we have total ordering. Latency 3 messages are sent in sequence, therefore it has a higher latency than sequencer method this ordering may not be causal or FIFO proof of total ordering on page 448 • 63

Causally ordered multicast We present an algorithm of Birman 1991 for causally ordered multicast in non-overlapping, closed groups. It uses the happened before relation (on multicast messages only) that is, ordering imposed by one-to-one messages is not taken into account It uses vector timestamps - that count the number of multicast messages from each process that happened before the next message to be multicast • 64

Causal ordering using vector timestamps each process has its own vector timestamp To CO-multicast m to g, a process adds 1 to its entry in the vector timestamp and B-multicasts m and the vector timestamp Figure 11.16 When a process B-delivers m, it places it in a hold-back queue until messages earlier in the causal ordering have been delivered:- a) earlier messages from same sender have been delivered b) any messages that the sender had delivered when it sent the multicast message have been delivered pi has delivered from pj Vi[j] pj has delivered Vj[k] need to wait until Vi[k]=>Vj[k] can CO-deliver to self immediately after B-multicast then it CO-delivers the message and updates its timestamp Note: a process can immediately CO-deliver to itself its own messages (not shown) • 65

for an outline of the proof see page 449 Comments after delivering a message from pj, process pi updates its vector timestamp by adding 1 to the jth element of its timestamp compare the vector clock rule where Vi[j] := max(Vi[j], t[j]) for j=1, 2, ...N in this algorithm we know that only the jth element will increase for an outline of the proof see page 449 if we use R-multicast instead of B-multicast then the protocol is reliable as well as causally ordered. If we combine it with the sequencer algorithm we get total and causal ordering • 66

Comments on multicast protocols we need to have protocols for overlapping groups because applications do need to subscribe to several groups definitions of ‘global FIFO ordering’ etc on page 450 and some references to papers on them multicast in synchronous and asynchronous systems all of our algorithms do work in both reliable and totally ordered multicast can be implemented in a synchronous system but is impossible in an asynchronous system (reasons discussed in consensus section - paper by Fischer et al.) • 67

Summary Multicast communication can specify requirements for reliability and ordering, in terms of integrity, validity and agreement B-multicast a correct process will eventually deliver a message provided the multicaster does not crash reliable multicast in which the correct processes agree on the set of messages to be delivered; we showed two implementations: over B-multicast and IP multicast delivery ordering FIFO, total and causal delivery ordering. FIFO ordering by means of senders’ sequence numbers total ordering by means of a sequencer or by agreement of sequence numbers between processes in a group causal ordering by means of vector timestamps the hold-back queue is a useful component in implementing multicast protocols • 68