Transport Layer3-1 Transport Layer Our goals: r understand principles behind transport layer services: m multiplexing/demultipl exing m reliable data transfer.

Slides:



Advertisements
Similar presentations
Transport Layer3-1 Transport Overview and UDP. Transport Layer3-2 Goals r Understand transport services m Multiplexing and Demultiplexing m Reliable data.
Advertisements

Introduction 1-1 Chapter 3 Transport Layer Intro and Multiplexing Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley.
Transport Layer 3-1 Chapter 3 Transport Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March 2012 A.
CPSC 441: Intro, UDP1 Transport Layer Instructor: Carey Williamson Office: ICT Class Location:
Some slides are in courtesy of J. Kurose and K. Ross Review of Previous Lecture Electronic Mail: SMTP, POP3, IMAP DNS Socket programming with TCP.
Computer Communication Digital Communication in the Modern World Transport Layer Multiplexing, UDP
Chapter 3: Transport Layer
Introduction to Transport Layer. Transport Layer: Motivation A B R1 R2 r Recall that NL is responsible for forwarding a packet from one HOST to another.
Transport Layer3-1 Transport Layer Our goals: r understand principles behind transport layer services: m multiplexing/demultipl exing m reliable data transfer.
Lecture 8 Chapter 3 Transport Layer
CPSC 441: Intro, UDP1 Instructor: Anirban Mahanti Office: ICT Class Location: ICT 121 Lectures: MWF 12:00 – 12:50 Notes.
1 Internet transport-layer protocols r reliable, in-order delivery (TCP) m congestion control m flow control m connection setup r unreliable, unordered.
Some slides are in courtesy of J. Kurose and K. Ross Review of Previous Lecture Electronic Mail: SMTP, POP3, IMAP DNS Socket programming with TCP.
Announcement Homework 1 due last night, how is that ? –Will discuss some problems in the lecture next week Should have completed at least part II of project.
3-1 Transport services and protocols r provide logical communication between app processes running on different hosts r transport protocols run in end.
1 Computer Networks Transport Layer Protocols. 2 Application-layer Protocols Application-layer protocols –one “piece” of an app –define messages exchanged.
8-1 Transport Layer Our goals: r understand principles behind transport layer services: m multiplexing/demultipl exing m reliable data transfer m flow.
Transport Layer Transport Layer. Transport Layer 3-2 Chapter 3 Transport Layer Computer Networking: A Top Down Approach Featuring the Internet,
Previous Lecture r P2P file sharing r Socket programming with TCP r Socket programming with UDP.
IP-UDP-RTP Computer Networking (In Chap 3, 4, 7) 건국대학교 인터넷미디어공학부 임 창 훈.
Review: –What is AS? –What is the routing algorithm in BGP? –How does it work? –Where is “policy” reflected in BGP (policy based routing)? –Give examples.
Data Communications and Computer Networks Chapter 3 CS 3830 Lecture 12 Omar Meqdadi Department of Computer Science and Software Engineering University.
CS 1652 The slides are adapted from the publisher’s material All material copyright J.F Kurose and K.W. Ross, All Rights Reserved Jack Lange.
Network LayerII-1 RSC Part III: Transport Layer 1. Basic Concepts Redes y Servicios de Comunicaciones Universidad Carlos III de Madrid These slides are,
Transport Layer 3-1 Chapter 3 Transport Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March 2012 All.
Transport Layer and UDP Tahir Azim Ref:
Transport Layer 3-1 Chapter 3 Transport Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March 2012 Part.
Chapter 3 Transport Layer
Transport Layer3-1 Chapter 3: Transport Layer Our goals: r understand principles behind transport layer services: m multiplexing/demultipl exing m reliable.
Transport Layer3-1 Chapter 3 Transport Layer These ppt slides are originally from the Kurose and Ross’s book. But some slides are deleted and added for.
Transport Layer 3-1 Chapter 3 Transport Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March 2012 A.
Transport Layer3-1 Chapter 3 Transport Layer Computer Networking: A Top Down Approach Featuring the Internet, 2 nd edition. Jim Kurose, Keith Ross Addison-Wesley,
Transport Layer3-1 Chapter 3: Transport Layer Our goals: r understand principles behind transport layer services: m multiplexing/demultipl exing m reliable.
Transport Layer1 Ram Dantu (compiled from various text books)
1 Transport Layer Lecture 7 Imran Ahmed University of Management & Technology.
Lecture91 Administrative Things r Return homework # 1 r Review some problems in homework # 1 r Questions about grading? Yona r WebCT for CSE245 is working!
The Transport Layer application transport network data link physical application transport network data link physical application transport network data.
CS 3830 Day 13 Introduction 1-1. Announcements r Quiz 3: Wednesday, Oct 10 r Prog3 due Wednesday, Oct 10 Transport Layer 3-2.
Transport Layer3-1 Chapter 3 Transport Layer Computer Networking: A Top Down Approach 4 th edition. Jim Kurose, Keith Ross Addison-Wesley, July A.
Transport Layer 3-1 Chapter 3 Outline r 3.1 Transport-layer services r 3.2 Multiplexing and demultiplexing r 3.3 Connectionless transport: UDP.
Chapter 3: Transport Layer Our goals: r understand principles behind transport layer services: m multiplexing/demultipl exing m reliable data transfer.
Transport Layer3-1 Chapter 3 Transport Layer Computer Networking: A Top Down Approach Featuring the Internet, 3 rd edition. Jim Kurose, Keith Ross Addison-Wesley,
Prof. Younghee Lee 1 1 Computer Networks u Lecture 5: Transport services and protocols Prof. Younghee Lee * Some part of this teaching materials are prepared.
MULTIPLEXING/DEMULTIPLEXING, CONNECTIONLESS TRANSPORT.
Transport Layer3-1 Chapter 3: Transport Layer Our goals: r understand principles behind transport layer services: m multiplexing/demultipl exing m reliable.
Application Layer 2-1 Chapter 3 Transport Layer Computer Networking: A Top Down Approach 6 th edition Jim Kurose, Keith Ross Addison-Wesley March 2012.
Introduction 1-1 source application transport network link physical HtHt HnHn M segment HtHt datagram destination application transport network link physical.
2: Transport Layer 11 Transport Layer 1. 2: Transport Layer 12 Part 2: Transport Layer Chapter goals: r understand principles behind transport layer services:
Spring 2006 CPE : Transport Layer Overview2-1 Special Topics in Computer Engineering The Transport Layer in the Internet: Overview Some of these.
@Yuan Xue A special acknowledge goes to J.F Kurose and K.W. Ross Some of the slides used in this lecture are adapted from their.
CSEN 404 Transport Layer I Amr El Mougy Lamia Al Badrawy.
Transport Layer3-1 Transport Layer Never take life seriously. Nobody gets out alive anyway.
Chapter 3 Transport Layer
Introduction to Networks
Chapter 3 Transport Layer
Transport Layer Slides are originally from instructor: Carey Williamson at University of Calgary Very minor modification are made Notes derived from “Computer.
Chapter 3 outline 3.1 Transport-layer services
06- Transport Layer Transport Layer.
CS 1652 Jack Lange University of Pittsburgh
Introduction to Networks
Transport Layer Our goals:
September 19th, 2013 CS1652 Jack Lange University of Pittsburgh
Transport Layer Our goals:
Chapter 3 Transport Layer
CSCD 330 Network Programming
Chapter 3 Transport Layer
Transport Layer Our goals:
Presentation transcript:

Transport Layer3-1 Transport Layer Our goals: r understand principles behind transport layer services: m multiplexing/demultipl exing m reliable data transfer m flow control m congestion control r learn about transport layer protocols in the Internet: m UDP: connectionless transport m TCP: connection-oriented transport m TCP congestion and flow control

Transport Layer3-2 Recap: Internet protocol stack r application: supporting network applications m FTP, SMTP, HTTP r transport: process-process data transfer m TCP, UDP r network: host-host data transfer m IP r link: data transfer between neighboring network elements m PPP, Ethernet r physical: bits “on the wire” application transport network link physical

Transport Layer3-3 message segment datagram frame source application transport network link physical HtHt HnHn HlHl M HtHt HnHn M HtHt M M destination application transport network link physical HtHt HnHn HlHl M HtHt HnHn M HtHt M M network link physical link physical HtHt HnHn HlHl M HtHt HnHn M HtHt HnHn HlHl M HtHt HnHn M HtHt HnHn HlHl M HtHt HnHn HlHl M router switch Encapsulation

Transport Layer3-4 TL: Outline r 3.1 Transport-layer services r 3.2 Multiplexing and demultiplexing r 3.3 Connectionless transport: UDP r 3.4 Principles of reliable data transfer r 3.5 Connection-oriented transport: TCP m segment structure m reliable data transfer m flow control m connection management r 3.6 Principles of congestion control r 3.7 TCP congestion control

Transport Layer3-5 Transport services and protocols r provide logical communication between app processes running on different hosts r transport protocols run in end systems m send side: breaks app messages into segments, passes to network layer (Multiplexing) m rcv side: reassembles segments into messages, passes to app layer (DeMultiplexing) r more than one transport protocol available to apps m TCP and UDP application transport network data link physical application transport network data link physical network data link physical network data link physical network data link physical network data link physical network data link physical logical end-end transport

Transport Layer3-6 Transport vs. network layer r network layer: logical communication between hosts r transport layer: logical communication between processes m relies on, enhances, network layer services m Constrained by network layer service: e.g. bounded delay m Enhancement: e.g. reliable data transfer, encryption to guarantee message secrecy Household analogy: 12 kids sending letters to 12 kids r processes = kids r app messages = letters in envelopes r hosts = houses r transport protocol = Ann and Bill: mail service to collect/distribute mails m Susan/Harvey can provide another type of mail service r network-layer protocol = postal service

Transport Layer3-7 Internet transport-layer protocols r IP service model m Host-to-host best-effort delivery service, datagram m Unreliable serivce r UDP: unreliable, unordered delivery m Proc to proc segment delivery: no- frills extension of “best-effort” IP (Multiplexing /demultiplexing) m Error checking r TCP: m reliable, in-order delivery: flow control, sequence number, ack, timer, etc m congestion control to prevent TCP connection from swamping the links and switches r services not available in either TCP or UDP: m delay guarantees m bandwidth guarantees application transport network data link physical application transport network data link physical network data link physical network data link physical network data link physical network data link physical network data link physical logical end-end transport

Transport Layer3-8 Multiplexing/demultiplexing (encode/decode) application transport network link physical P1 application transport network link physical application transport network link physical P2 P3 P4 P1 host 1 host 2 host 3 = process= socket The job of delivering received transport-layer segments to correct socket. Each socket has a unique identifier (a set of fields in each segment) Demultiplexing at rcv host: The job of gathering data from different sockets, enveloping data with header (later used for demultiplexing) and passing the data to the network layer. Multiplexing at send host:

Transport Layer3-9 How demultiplexing works r host receives IP datagrams m each datagram has source and destination IP addresses m each datagram carries 1 transport-layer segment m each segment has source, destination port number (ranges from ) m 0~1023 well-known ports r host/OS uses IP addresses & port numbers to direct segment to appropriate socket source port #dest port # 32 bits application data (message) other header fields TCP/UDP segment format Note the naming convention: IP datagrams vs TCP/UDP segments

Transport Layer3-10 Connectionless demultiplexing r Create UDP sockets with port numbers; the OS assigns ports if not specified by programmer: DatagramSocket mySocket1 = new DatagramSocket(99111); DatagramSocket mySocket2 = new DatagramSocket(); r UDP socket is identified by two-tuple: ( dest IP address, dest port number) r When host/server receives UDP segment: m checks destination port number in segment m directs UDP segment to socket with that port number r IP datagrams with different source IP addresses and/or source port numbers directed to same socket

Transport Layer3-11 Connectionless demux (cont) DatagramSocket serverSocket = new DatagramSocket(6428); Client IP:B P2 client IP: A P1 P3 server IP: C SP: 6428 DP: 9157 SP: 9157 DP: 6428 SP: 6428 DP: 5775 SP: 5775 DP: 6428 SP = Source Port, DP = Destination Port Source Packet provides “return address” that destination host can use to reply port 9157 port 6428port 5775 One Server Socket

Transport Layer3-12 Connection-oriented demux r TCP socket identified by 4- tuple: m source IP address m source port number m dest IP address m dest port number r recv host uses all four values to direct segment to appropriate socket r Server host may support many simultaneous TCP sockets: m each socket identified by its own 4-tuple m TCP server appl has a “welcome socket”, waiting for conneciton-setup requests r Web servers have different sockets for each connecting client m non-persistent HTTP will have different socket for each request because it re- connects at each request.

Transport Layer3-13 Recap: Client/server TCP socket interaction wait for incoming connection request connectionSocket = welcomeSocket.accept() create socket, port= x, for incoming request: welcomeSocket = ServerSocket() create socket, connect to hostid, port= x clientSocket = Socket() close connectionSocket read reply from clientSocket close clientSocket Server (running on hostid ) Client send request using clientSocket read request from connectionSocket write reply to connectionSocket TCP connection setup

Transport Layer3-14 Connection-oriented demux (Web Server example 1) Client IP:B P1 client IP: A P1P2P4 server IP: C SP: 9157 DP: 80 SP: 9157 DP: 80 P5P6P3 D-IP:C S-IP: A D-IP:C S-IP: B SP: 5775 DP: 80 D-IP:C S-IP: B SP = Source Port, DP = Destination Port, S-IP = Source IP, D-IP = Destination IP Three Server Sockets

Transport Layer3-15 Connection-oriented demux: (Web Server example 2) Client IP:B P1 client IP: A P1P2 server IP: C SP: 9157 DP: 80 SP: 9157 DP: 80 P4 P3 D-IP:C S-IP: A D-IP:C S-IP: B SP: 5775 DP: 80 D-IP:C S-IP: B

Transport Layer3-16 Transport Layer: Outline r 3.1 Transport-layer services r 3.2 Multiplexing and demultiplexing r 3.3 Connectionless transport: UDP r 3.4 Principles of reliable data transfer r 3.5 Connection-oriented transport: TCP m segment structure m reliable data transfer m flow control m connection management r 3.6 Principles of congestion control r 3.7 TCP congestion control

Transport Layer3-17 UDP: User Datagram Protocol [RFC 768] r “no frills,” “bare bones” Internet transport protocol r “best effort” service, UDP segments may be: m lost m delivered out of order to app r connectionless: m no handshaking between UDP sender, receiver m each UDP segment handled independently of others Why is there a UDP? r no connection establishment (which can add delay) r simple: no connection state (parameters,buffers) at sender, receiver r small segment header, 8 bytes for UDP vs 20 bytes for TCP per segment. r Finer application control on what and when to send data.no congestion control.

Transport Layer3-18 Internet Applications that use UDP r Domain Name Service (DNS): m DNS would be much slower if it ran over TCP r Network Management Applications: using Simple Network Management Protocol (SNMP): m they often run when the network is in a stressed state and TCP and its overhead is difficult to achieve. r Multimedia appl: Internet phone, real-time video conf. that can tolerate small packet loss and is sensitive to transfer rates. m reliability can be built into the application that have their own acknowledgements and retransmissions techniques. But UDP senders may crowd out TCP sessions

Transport Layer3-19 UDP Segment Structure r UDP segment has an 8 byte header. r Length of UDP segment, in bytes, including header. r Minimum length is 8 and maximum is 64k. source port #dest port # 32 bits Application data (message) UDP segment format length (16-bit) checksum (16-bit)

Transport Layer3-20 UDP checksum Sender: r treat segment contents as sequence of 16-bit integers (words) r checksum: 1’s complement of the addition of all segment words with overflow wrapped around r sender puts checksum value into UDP checksum field Receiver: r compute sum of all 16-bit words including checksum in received segment r check if computed sum equals all 1’s: m NO - error detected m YES - no error detected. Goal: detect “errors” due to noise or router storage (e.g., flipped bits) in transmitted segment. A damaged packet is sometimes passed to the appl. with a warning or sometime discarded. All 1-bit errors will be detected but two-bit errors can be undetected

Transport Layer3-21 Internet Checksum: Sender Example r Note m When adding numbers, a carryout from the most significant bit needs to be added to the result r Segment has two 16-bit integers and the checksum r Add the two 16-bit integers r compute the checksum by taking the 1’s complement of the sum wraparound: add carry to LSB sum checksum

Transport Layer3-22 r Compute the sum of all 16-bit words including the checksum. r If All 1’s then no error wraparound: add carry to LSB sum checksum Internet Checksum: Receiver Example - no errors sum (All 1s)

Transport Layer3-23 r Compute the sum of all 16-bit words including the checksum. r If All 1’s then no error wraparound: add carry to LSB sum checksum Checksum: Receiver Example - 1 bit error Flipped bit sum (not all 1s)

Transport Layer3-24 r Compute the sum of all 16-bit words including the checksum. r If All 1’s then no error ! sum checksum Checksum: Receiver Example - 3 bit error undetected sum (All 1s) Flipped bits circled

Transport Layer3-25 Why Checksum at TL layer r No guarantee that all the links between src and dest provide error checking r Bit errors may be introduced in a router’s memory r An example of end-to-end design principle m End-to-end data transfer with error detection

Transport Layer3-26 Summary r Transport layer vs Network layer m logical communication between processes vs between hosts r Transport Layer minimum services: m Multiplexing and DeMultiplexing of application layer packets m Data error handling via checksums. r Difference between Multiplexing at send host vs Demultiplexing at rcv host r UDP Socket vs TCP Socket identification parameters m (dest-IP, dest-port) vs (source-IP, source-port, dest-IP, dest- port) r UDP Advantages over TCP and what type of applications use it. r UDP Segment Structure and the checksum calculation for handling 1- bit errors