7/26/2001 1 Design and Implementation of a Simple Totally-Ordered Reliable Multicast Protocol in Java.

Slides:



Advertisements
Similar presentations
Push Technology Humie Leung Annabelle Huo. Introduction Push technology is a set of technologies used to send information to a client without the client.
Advertisements

CCNA – Network Fundamentals
Chapter 7: Transport Layer
© 2008 Cisco Systems, Inc. All rights reserved.Cisco ConfidentialPresentation_ID 1 Chapter 7: Transport Layer Introduction to Networking.
Transport Layer – TCP (Part1) Dr. Sanjay P. Ahuja, Ph.D. Fidelity National Financial Distinguished Professor of CIS School of Computing, UNF.
© 2007 Cisco Systems, Inc. All rights reserved.Cisco Public 1 Version 4.0 OSI Transport Layer Network Fundamentals – Chapter 4.
EEC-484/584 Computer Networks Lecture 12 Wenbing Zhao (Part of the slides are based on Drs. Kurose & Ross ’ s slides for their Computer.
Group Communications Group communication: one source process sending a message to a group of processes: Destination is a group rather than a single process.
Multicast Communication
WXES2106 Network Technology Semester /2005 Chapter 8 Intermediate TCP CCNA2: Module 10.
3-1 Transport services and protocols r provide logical communication between app processes running on different hosts r transport protocols run in end.
Error Checking continued. Network Layers in Action Each layer in the OSI Model will add header information that pertains to that specific protocol. On.
Multicast Transport Protocols: A Survey and Taxonomy Author: Katia Obraczka University of Southern California Presenter: Venkatesh Prabhakar.
Gursharan Singh Tatla Transport Layer 16-May
Process-to-Process Delivery:
2-2008UP-Copyrights reserved1 ITGD4103 Data Communications and Networks OSI Reference Model Lecture-5: OSI Reference Model week 5- q-2/ 2008 Dr. Anwar.
Mapping Internet Addresses to Physical Addresses (ARP)
Presentation on Osi & TCP/IP MODEL
© 2008 Cisco Systems, Inc. All rights reserved.Cisco ConfidentialPresentation_ID 1 Chapter 7: Transport Layer Introduction to Networking.
CECS 474 Computer Network Interoperability Notes for Douglas E. Comer, Computer Networks and Internets (5 th Edition) Tracy Bradley Maples, Ph.D. Computer.
IP and Errors IP Best Effort Datagrams can be: –Lost –Delayed –Duplicated –Delivered out of order –Corrupted.
6.1. Transport Control Protocol (TCP) It is the most widely used transport protocol in the world. Provides reliable end to end connection between two hosts.
TCP/IP Essentials A Lab-Based Approach Shivendra Panwar, Shiwen Mao Jeong-dong Ryoo, and Yihan Li Chapter 5 UDP and Its Applications.
© 2002, Cisco Systems, Inc. All rights reserved..
SPREAD TOOLKIT High performance messaging middleware Presented by Sayantam Dey Vipin Mehta.
TCP Lecture 13 November 13, TCP Background Transmission Control Protocol (TCP) TCP provides much of the functionality that IP lacks: reliable service.
University of the Western Cape Chapter 12: The Transport Layer.
SMUCSE 4344 transport layer. SMUCSE 4344 transport layer end-to-end protocols –transport code runs only on endpoint hosts encapsulates network communications.
TCP1 Transmission Control Protocol (TCP). TCP2 Outline Transmission Control Protocol.
The Transmission Control Protocol (TCP) Application Services (Telnet, FTP, , WWW) Reliable Stream Transport (TCP) Connectionless Packet Delivery.
Chi-Cheng Lin, Winona State University CS 313 Introduction to Computer Networking & Telecommunication Data Link Layer Part I – Designing Issues and Elementary.
1. I NTRODUCTION TO N ETWORKS Network programming is surprisingly easy in Java ◦ Most of the classes relevant to network programming are in the java.net.
Transport Control Protocol (TCP) Features of TCP, packet loss and retransmission, adaptive retransmission, flow control, three way handshake, congestion.
COP 4930 Computer Network Projects Summer C 2004 Prof. Roy B. Levow Lecture 3.
Chapter 5 Peer-to-Peer Protocols and Data Link Layer PART I: Peer-to-Peer Protocols ARQ Protocols and Reliable Data Transfer Flow Control.
Group Communication Group oriented activities are steadily increasing. There are many types of groups:  Open and Closed groups  Peer-to-peer and hierarchical.
Lecture 4 Overview. Ethernet Data Link Layer protocol Ethernet (IEEE 802.3) is widely used Supported by a variety of physical layer implementations Multi-access.
Institute of Technology Sligo - Dept of Computing Chapter 12 The Transport Layer.
Computer Networks23-1 PART 5 Transport Layer. Computer Networks23-2 Position of Transport Layer Responsible for the delivery of a message from one process.
Distributed systems (NET 422) Prepared by Dr. Naglaa Fathi Soliman Princess Nora Bint Abdulrahman University College of computer.
Today’s topic: UDP Reliable communication over UDP.
Transmission Control Protocol (TCP) BSAD 146 Dave Novak Sources: Network+ Guide to Networks, Dean 2013.
IP1 The Underlying Technologies. What is inside the Internet? Or What are the key underlying technologies that make it work so successfully? –Packet Switching.
Fault Tolerance (2). Topics r Reliable Group Communication.
IT 424 Networks2 IT 424 Networks2 Ack.: Slides are adapted from the slides of the book: “Computer Networking” – J. Kurose, K. Ross Chapter 3: Transport.
McGraw-Hill Chapter 23 Process-to-Process Delivery: UDP, TCP Copyright © The McGraw-Hill Companies, Inc. Permission required for reproduction or display.
TCP/IP1 Address Resolution Protocol Internet uses IP address to recognize a computer. But IP address needs to be translated to physical address (NIC).
Transmission Control Protocol (TCP) TCP Flow Control and Congestion Control CS 60008: Internet Architecture and Protocols Department of CSE, IIT Kharagpur.
Computer Networking Lecture 16 – Reliable Transport.
Group Communication A group is a collection of users sharing some common interest.Group-based activities are steadily increasing. There are many types.
3. END-TO-END PROTOCOLS (PART 1) Rocky K. C. Chang Department of Computing The Hong Kong Polytechnic University 22 March
Chapter 3: The Data Link Layer –to achieve reliable, efficient communication between two physically connected machines. –Design issues: services interface.
Chapter 7: Transport Layer
Chapter 9: Transport Layer
Fast Retransmit For sliding windows flow control we waited for a timer to expire before beginning retransmission of a packet TCP uses an additional mechanism.
Instructor Materials Chapter 9: Transport Layer
Chapter 3 Internet Applications and Network Programming
Process-to-Process Delivery, TCP and UDP protocols
PART 5 Transport Layer Computer Networks.
Introduction of Transport Protocols
Transport Layer Unit 5.
Transport Layer Our goals:
Process-to-Process Delivery:
CS412 Introduction to Computer Networking & Telecommunication
Chapter 5 Peer-to-Peer Protocols and Data Link Layer
Chapter 10 IGMP Prof. Choong Seon HONG.
Chapter 5 Peer-to-Peer Protocols and Data Link Layer
Lecture 4 Peer-to-Peer Protocols and Data Link Layer
Computer Networks Protocols
Transport Layer 9/22/2019.
Presentation transcript:

7/26/ Design and Implementation of a Simple Totally-Ordered Reliable Multicast Protocol in Java

7/26/ Introduction

7/26/ Background –Computer networks allow geographically distributed processes to collaborate or share a common stream of information. –Major characteristic of group communication applications is one source sends data to multiple receivers. –Multicast is well-suited for the distributed applications that focus on group activities, compared with unicast and broadcast.

7/26/ Multicast Multicast aims to deliver data to a select group of hosts. A single packet is addressed to all intended hosts and the network replicates packets only as needed. IP Multicast is an internet protocol that enables transmission of data to a group of receivers. IP Multicast is unreliable.

7/26/ Reliability –guarantees data eventually delivered to non- faulty receivers. Totally-ordered Reliable Multicast Total Ordering –all receivers observe the same order of reception of messages.

7/26/ Easy to build networking applications. Portable to any systems. Object oriented - clearer structure, supports reuse. Java

7/26/ session –a collaborative group, includes a collection of processes. –members cooperate to fulfill a common goal or share a common stream of information. channel –the communication pipe for session members. –encapsulates the transmission protocol to session members. Basic Concepts(1)

7/26/ session name server –a program running at a well-known address. –maintains a list of the current sessions along with session member information. default channel –a special channel, created for each session when the session is created. –the services of a session are implemented through the default channel. Basic Concepts(2)

7/26/ Session() int join(String name, int netmask) int leave() int query(Session_Info si) Channel() int join(Session s, String cname) int send(int sid, byte[] buffer) int receive(int sid, byte[] buffer) int leave() User-level API

7/26/ import TRMP.*; import java.lang.*; public class Test implements Constants{ public static void main(String[] args){ Session s = new Session(); long netmask = Long.parseLong(args[0], 16); s.join(“s1”, netmask); Channel ch = new Channel(); ch.join(s, “c1”); String str = “Hello."; byte[] bytes = str.getBytes(); ch.send(ALL,bytes); ch.leave(); s.leave(); } } * Appendix A Sample Testing Program

7/26/ Design

7/26/ Reliability Ordering Flow Control Design Considerations

7/26/ (hybrid) sender-initiated approach. sender maintains status of all receivers. timers used for detecting ACK losses. Reliability (sender)

7/26/ senderreceiver timeout Reliability (sender) ACK

7/26/ sends ACKs. detects out of ordered packets, and sends NAK when discontinued packet sequence number is detected. timers applied for the loss of NAKs. suppress ACKs for fragmented packets. Reliability (receiver)

7/26/ Reliability (receiver) sender receiver NAK

7/26/ a centralized scheme, one process sequences all the messages in a group. TCP tunneling and multicasting locally. large messages fragmented before multicasting and reassembled by receivers. Ordering

7/26/ LAN 2 LAN 1LAN 3 TCP multicast

7/26/ sliding window mechanism. fixed window size for simplicity. bounds buffers. Flow Control

7/26/ Implementation

7/26/ Session owner –the oldest member in a session –grants session membership and sequences the membership messages sent in the default channel. Membership database –kept on each session member. –contains current session and channel information. Membership messages –contain session and channel membership updates. Additional Concepts(1)

7/26/ Channel leader –the oldest channel member in a channel. –sequence the messages transmitted in the channel. Multicaster –the oldest channel member in one subnet of the channel. –multicast the messages within its subnet. Additional Concepts(2)

7/26/ Architecture

7/26/ Session Name Server Session information is provided to processes when they join a session. SNS accepts four types of messages. –joining session request. –leaving session request –terminating session request. –querying sessions request.

7/26/ The Default Channel –automatically joins when a process joins a session. –contains all the session members. –transmits the membership messages. –session owner sequences the membership messages. –supports reliable point to point message (TCP) as well as multicasting.

7/26/ Example Configuration of a Session with Two Channels SNS channel 1 channel 2 default channel LAN 4 LAN 3 LAN 2 LAN 1

7/26/ Session –session and channel membership database created locally when a process joins a session. –members update the membership database whenever they receive join and leave session, join and leave channel, and crash (leave) messages. –provides the same views of the session and channels states to all the session members.

7/26/ Channel –provide totally-ordered reliable multicast message delivery to channel members by TCP tunneling and local multicasting. –multiple channels may exist simultaneously in one session. –one session member may join more than one channel at a time. –members of a channel divided into subnet groups according to their subnet address.

7/26/ LAN 2 LAN 1LAN 3 TCP multicast channel leader multicaster TCP data source

7/26/ Session and Related Classes (UML)

7/26/ Channel and Related Classes (UML)

7/26/ Threads Synchronization In Java, each object has a monitor associated with it. No two threads can acquire an object's monitor at the same time. Multiple threads can synchronize access to an object with each other through the use of wait()/notify() calls. Multithread synchronization is heavily used in the implementation.

7/26/ Multithread Synchronization public synchronized void handleNackEvent() { while (true) { if ( mcrt.lostMsgs.size() == 0) wait(); //mcrt.lostMsgs is the lost message queue... } public synchronized void requestResend(int seq) { // add new element to the list with associated information... if ( mcrt.lostMsgs.size() == 1 ) notify(); }

7/26/ Multithread Synchronization MCReceiveThreadNackThread NackThread() initialization requestResend() update lost queue handleNackEvent() notify() detect message lost acquire lock ask for resend to the multicaster lost message queue is empty wait() receive resent message cancelResend() update lost queue release lock

7/26/ Testing

7/26/ Functions Tested –session name server support. –join and leave session, channels. –ordering. –reliability. –failure handling (message loss, host crash). –performance.

7/26/ Testing Environment labss3alabss4alabss3dlabss4dcompute paladin jet muck LAN1 LAN2 LAN3 session s1 channel c1Channel c2 SNS

7/26/ Performance Test Purpose: To compare TRMP latency with TCP (base line). Result: TRMP has lower latency for more than 12 receivers.

7/26/ TRMP Vs. TCP

7/26/ Summary –We have designed and implemented a totally- ordered reliable multicast protocol (TRMP) in Java. –Simple test applications are implemented to test the functions and the performance of the protocol. The test results show that the protocol can provide totally-ordered reliable multicast with reasonable speed. –The TRMP package contains 38 classes and 4,661 lines of Java code.

7/26/ Related Work –Group Communication Support for Distributed Collaboration System (CCTL). –A Reliable Multicast Framework for Light- Weight Sessions and Application Level Framing (SRM). –Reliable Multicasting of Continuous Data Streams (RMTP). –The Java Reliable Multicast Service: A Reliable Multicast Library(JRMS).

7/26/ Future Work flexible window size different types of quality of service NAK and re-transmission suppression performance

7/26/ Thank you !