Lecture 12-13. Transport Layer
Lecture 12-13. Transport Layer
Lecture 12-13. Transport Layer
Transport layer
Introduction to
Transport Layer
• The transport layer is located
between the network layer
and the application layer
• The transport layer provides
a process to process
communication between two
application layers
• Communication is provided
using a logical connection
• The transport layer is
responsible for providing
services to the application
layer
Process to Process
Communication (1#3)
• A network-layer protocol can deliver the message
only to the destination computer
• A transport-layer protocol is responsible for
delivery of the message to the appropriate
process
Process to Process
Communication (2#3)
• For communication, we must define the local host, local process,
remote host, and remote process
• The local host and the remote host are defined using IP addresses
• To define the processes, we need second identifiers, called port
numbers.
• In the TCP/IP protocol suite, the port numbers are integers between 0
and 65,535 (16 bits)
Process to Process
Communication (3#3)
• The destination IP address defines the host among the different hosts
in the world
• The port number defines one of the processes on this particular host
ICANN Port Ranges
(1#2)
• Well-known ports. The ports ranging from 0 to 1023 are assigned
and controlled by ICANN. These are the well-known ports.
• Registered ports. The ports ranging from 1024 to 49,151 are not
assigned or controlled by ICANN. They can only be registered with
ICANN to prevent duplication.
• Dynamic ports. The ports ranging from 49,152 to 65,535 are neither
controlled nor registered. They can be used as temporary or private
port numbers
ICANN Port Ranges
(2#2)
• A transport layer protocol in the TCP suite needs both the IP address
and the port number, at each end, to make a connection
• The combination of an IP address and a port number is called a
socket address
• To use the services of the transport layer in the Internet, we need a
pair of socket addresses: the client socket address and the server
socket address
•
Encapsulation and
Decapsulation
• To send a message from one process to another, the transport layer
protocol encapsulates and decapsulates messages
• The transport layer receives the data and adds the transport-layer
header
• The packets at the transport layer in the Internet are called user
datagrams, segments, or packets, depending on what transport-layer
protocol we use
• Decapsulation happens at the receiver site
Multiplexing and
Demultiplexing
• Whenever an entity
accepts items from more
than one source, this is
referred to as multiplexing
(many to one)
• Whenever an entity delivers
items to more than one
source, this is referred to as
demultiplexing (one to
many)
• The transport layer at the
source performs multiplexing
• the transport layer at the
destination performs
demultiplexing
Flow Control
• Delivery of items from a producer to a consumer can
occur in one of two ways: pushing or pulling
Flow Control at
Transport Layer
• In communication at the transport layer, we are dealing with four
entities: sender process, sender transport layer, receiver transport
layer, and receiver process
• Although flow control can be implemented in several ways, one of the
solutions is normally to use two buffers: one at the sending transport
layer and the other at the receiving transport layer
Error Control (1#2)
• Reliability can be achieved to add error control services to
the transport layer
• Error control at the transport layer is responsible for
– Detecting and discarding corrupted packets
– Keeping track of lost and discarded packets and resending them
– Recognizing duplicate packets and discarding them
– Buffering out of order packets until the missing packets arrive
Error Control (2#2)
• Error control requires that the sending transport
layer knows which packet is to be resent and the
receiving transport layer knows which packet is a
duplicate, or which packet has arrived out of
order
• We can add a field to the transport-layer packet
to hold the sequence number of the packet
• Packets are numbered sequentially
• The out-of-order packets can be recognized by
observing gaps in the sequence numbers
Combination of Flow
and Error Control
• Flow control requires the use of two buffers, one
at the sender site and the other at the receiver
site
• The buffer is represented as a set of slices, called the
sliding window, that occupies part of the circle at any
time
Congestion Control
• An important issue in a packet-switched network,
such as the Internet, is congestion
• Congestion control refers to the mechanisms
and techniques that control the congestion and
keep the load below the capacity
• Congestion in a network or internetwork occurs
because routers and switches have queues —
buffers that hold the packets before and after
processing
Connectionless and Connection
Oriented Protocols (1#2)
• A transport-layer protocol, like a network-layer protocol,
can provide two types of services:
– Connectionless
– Connection oriented
Connectionless and Connection
Oriented Protocols (2#2)