
In
computer network
A computer network is a collection of communicating computers and other devices, such as printers and smart phones. In order to communicate, the computers and devices must be connected by wired media like copper cables, optical fibers, or b ...
ing, the transport layer is a conceptual division of methods in the
layered architecture of protocols in the network stack in the
Internet protocol suite
The Internet protocol suite, commonly known as TCP/IP, is a framework for organizing the communication protocols used in the Internet and similar computer networks according to functional criteria. The foundational protocols in the suite are ...
and the
OSI model
The Open Systems Interconnection (OSI) model is a reference model developed by the International Organization for Standardization (ISO) that "provides a common basis for the coordination of standards development for the purpose of systems inter ...
. The protocols of this layer provide end-to-end communication services for applications. It provides services such as
connection-oriented communication,
reliability,
flow control, and
multiplexing.
The details of implementation and semantics of the transport layer of the
Internet protocol suite
The Internet protocol suite, commonly known as TCP/IP, is a framework for organizing the communication protocols used in the Internet and similar computer networks according to functional criteria. The foundational protocols in the suite are ...
, which is the foundation of the
Internet
The Internet (or internet) is the Global network, global system of interconnected computer networks that uses the Internet protocol suite (TCP/IP) to communicate between networks and devices. It is a internetworking, network of networks ...
, and the
OSI model
The Open Systems Interconnection (OSI) model is a reference model developed by the International Organization for Standardization (ISO) that "provides a common basis for the coordination of standards development for the purpose of systems inter ...
of general networking are different. The protocols in use today in this layer for the Internet all originated in the development of TCP/IP. In the OSI model the transport layer is often referred to as Layer 4, or L4, while numbered layers are not used in TCP/IP.
The best-known transport protocol of the Internet protocol suite is the
Transmission Control Protocol
The Transmission Control Protocol (TCP) is one of the main communications protocol, protocols of the Internet protocol suite. It originated in the initial network implementation in which it complemented the Internet Protocol (IP). Therefore, th ...
(TCP). It is used for connection-oriented transmissions, whereas the connectionless
User Datagram Protocol
In computer networking, the User Datagram Protocol (UDP) is one of the core communication protocols of the Internet protocol suite used to send messages (transported as datagrams in Network packet, packets) to other hosts on an Internet Protoco ...
(UDP) is used for simpler messaging transmissions. TCP is the more complex protocol, due to its
stateful design incorporating reliable transmission and data stream services. Together, TCP and UDP comprise essentially all traffic on the Internet and are the only protocols implemented in every major operating system. Additional transport layer protocols that have been defined and implemented include the
Datagram Congestion Control Protocol (DCCP) and the
Stream Control Transmission Protocol
The Stream Control Transmission Protocol (SCTP) is a computer networking communications protocol in the transport layer of the Internet protocol suite. Originally intended for Signaling System 7 (SS7) message transport in telecommunication, the ...
(SCTP).
Services
Transport layer services are conveyed to an application via a programming interface to the transport layer protocols. The services may include the following features:
*
Connection-oriented communication: It is normally easier for an application to interpret a connection as a
data stream rather than having to deal with the underlying connection-less models, such as the
datagram
A datagram is a basic transfer unit associated with a packet-switched network. Datagrams are typically structured in header and payload sections. Datagrams provide a connectionless communication service across a packet-switched network. The de ...
model of the
User Datagram Protocol
In computer networking, the User Datagram Protocol (UDP) is one of the core communication protocols of the Internet protocol suite used to send messages (transported as datagrams in Network packet, packets) to other hosts on an Internet Protoco ...
(UDP) and of the
Internet Protocol
The Internet Protocol (IP) is the network layer communications protocol in the Internet protocol suite for relaying datagrams across network boundaries. Its routing function enables internetworking, and essentially establishes the Internet.
IP ...
(IP).
* Same order delivery: The network layer doesn't generally guarantee that packets of data will arrive in the same order that they were sent, but often this is a desirable feature. This is usually done through the use of segment numbering, with the receiver passing them to the application in order. This can cause
head-of-line blocking.
*
Reliability: Packets may be lost during transport due to
network congestion and errors. By means of an
error detection code, such as a
checksum, the transport protocol may check that the data is not corrupted, and verify correct receipt by sending an
ACK or
NACK message to the sender.
Automatic repeat request
Automatic repeat request (ARQ), also known as automatic repeat query, is an error-control method for data transmission that uses acknowledgements (messages sent by the receiver indicating that it has correctly received a message) and timeout ...
schemes may be used to retransmit lost or corrupted data.
*
Flow control: The rate of data transmission between two nodes must sometimes be managed to prevent a fast sender from transmitting more data than can be supported by the receiving
data buffer, causing a buffer overrun. This can also be used to improve efficiency by reducing
buffer underrun.
*
Congestion avoidance:
Congestion control can control traffic entry into a telecommunications network, so as to avoid
congestive collapse by attempting to avoid oversubscription of any of the processing or
link capabilities of the intermediate nodes and networks and taking resource reducing steps, such as reducing the rate of sending
packets. For example,
automatic repeat request
Automatic repeat request (ARQ), also known as automatic repeat query, is an error-control method for data transmission that uses acknowledgements (messages sent by the receiver indicating that it has correctly received a message) and timeout ...
s may keep the network in a congested state; this situation can be avoided by adding congestion avoidance to the flow control, including
slow start. This keeps the bandwidth consumption at a low level in the beginning of the transmission, or after packet retransmission.
*
Multiplexing:
Ports Ports collections (or ports trees, or just ports) are the sets of makefiles and Patch (Unix), patches provided by the BSD-based operating systems, FreeBSD, NetBSD, and OpenBSD, as a simple method of installing software or creating binary packages. T ...
can provide multiple endpoints on a single node. For example, the name on a postal address is a kind of multiplexing and distinguishes between different recipients of the same location. Computer applications will each listen for information on their own ports, which enables the use of more than one
network service
In computer networking, a network service is an application running at the network layer and above, that provides data storage, manipulation, presentation, communication or other capability which is often implemented using a client–server or pe ...
at the same time. It is part of the transport layer in the
TCP/IP model, but of the
session layer in the OSI model.
Analysis
The transport layer is responsible for delivering data to the appropriate application process on the host computers. This involves
statistical multiplexing of data from different application processes, i.e. forming data segments, and adding source and destination port numbers in the header of each transport layer data segment. Together with the source and destination IP address, the port numbers constitute a
network socket, i.e. an identification address of the process-to-process communication. In the OSI model, this function is supported by the
session layer.
Some transport layer protocols, for example TCP, but not UDP, support
virtual circuit
A virtual circuit (VC) is a means of transporting data over a data network, based on packet switching and in which a connection is first established across the network between two endpoints. The network, rather than having a fixed data rate reser ...
s, i.e. provide
connection-oriented communication over an underlying packet-oriented
datagram
A datagram is a basic transfer unit associated with a packet-switched network. Datagrams are typically structured in header and payload sections. Datagrams provide a connectionless communication service across a packet-switched network. The de ...
network. A byte stream is delivered while hiding the packet mode communication for the application processes. This involves connection establishment, dividing of the data stream into packets called segments, segment numbering and reordering of out-of-order data.
Finally, some transport layer protocols, for example TCP, but not UDP, provide end-to-end reliable communication, i.e.
error recovery by means of
error detecting code and
automatic repeat request
Automatic repeat request (ARQ), also known as automatic repeat query, is an error-control method for data transmission that uses acknowledgements (messages sent by the receiver indicating that it has correctly received a message) and timeout ...
(ARQ) protocol. The ARQ protocol also provides
flow control, which may be combined with
congestion avoidance.
UDP is a very simple protocol and does not provide virtual circuits, nor reliable communication, delegating these functions to the
application program. UDP packets are called
datagram
A datagram is a basic transfer unit associated with a packet-switched network. Datagrams are typically structured in header and payload sections. Datagrams provide a connectionless communication service across a packet-switched network. The de ...
s, rather than segments.
TCP is used for many protocols, including
HTTP
HTTP (Hypertext Transfer Protocol) is an application layer protocol in the Internet protocol suite model for distributed, collaborative, hypermedia information systems. HTTP is the foundation of data communication for the World Wide Web, wher ...
web browsing and email transfer. UDP may be used for
multicasting and
broadcasting
Broadcasting is the data distribution, distribution of sound, audio audiovisual content to dispersed audiences via a electronic medium (communication), mass communications medium, typically one using the electromagnetic spectrum (radio waves), ...
, since retransmissions are not possible to a large amount of hosts. UDP typically gives higher
throughput
Network throughput (or just throughput, when in context) refers to the rate of message delivery over a communication channel in a communication network, such as Ethernet or packet radio. The data that these messages contain may be delivered ov ...
and shorter latency and is therefore often used for real-time multimedia communication where packet loss occasionally can be accepted, for example IP-TV and IP-telephony, and for online computer games.
Many non-IP-based networks, such as
X.25
X.25 is an ITU-T standard protocol suite for Packet switched network, packet-switched data communication in wide area network, wide area networks (WAN). It was originally defined by the CCITT, International Telegraph and Telephone Consultative Co ...
,
Frame Relay
Frame Relay (FR) is a standardized wide area network (WAN) technology that specifies the Physical layer, physical and data link layers of digital telecommunications channels using a packet switching methodology.
Frame Relay was originally devel ...
and
ATM, implement the connection-oriented communication at the network or data link layer rather than the transport layer. In X.25, in telephone network modems and in wireless communication systems, reliable node-to-node communication is implemented at lower protocol layers.
The OSI connection-mode transport layer protocol specification defines five classes of transport protocols: ''TP0'', providing the least error recovery, to ''TP4'', which is designed for less reliable networks.
Due to
protocol ossification, TCP and UDP are the only widely used transport protocols on the Internet. To avoid
middlebox intolerance, new transport protocols may mimic the
wire image of a tolerated protocol, or
be encapsulated in UDP, accepting some overhead (e.g., due to outer checksums made redundant by inner integrity checks).
QUIC takes the latter approach, rebuilding reliable stream transport on top of UDP.
Protocols
This list shows some protocols that are commonly placed in the transport layers of the
Internet protocol suite
The Internet protocol suite, commonly known as TCP/IP, is a framework for organizing the communication protocols used in the Internet and similar computer networks according to functional criteria. The foundational protocols in the suite are ...
, the
OSI protocol suite,
NetWare's
IPX/SPX,
AppleTalk, and
Fibre Channel
Fibre Channel (FC) is a high-speed data transfer protocol providing in-order, lossless delivery of raw block data. Fibre Channel is primarily used to connect computer data storage to Server (computing), servers in storage area networks (SAN) in ...
.
* ATP,
AppleTalk Transaction Protocol
* CUDP,
Cyclic UDP
* DCCP,
Datagram Congestion Control Protocol
* FCP,
Fibre Channel Protocol
* IL,
IL Protocol
* MPTCP,
Multipath TCP
* NORM,
NACK-Oriented Reliable Multicast
*
QUIC
* RDP,
Reliable Data Protocol
* RUDP,
Reliable User Datagram Protocol
* SCTP,
Stream Control Transmission Protocol
The Stream Control Transmission Protocol (SCTP) is a computer networking communications protocol in the transport layer of the Internet protocol suite. Originally intended for Signaling System 7 (SS7) message transport in telecommunication, the ...
* SPX,
Sequenced Packet Exchange
* SST,
Structured Stream Transport
* TCP,
Transmission Control Protocol
The Transmission Control Protocol (TCP) is one of the main communications protocol, protocols of the Internet protocol suite. It originated in the initial network implementation in which it complemented the Internet Protocol (IP). Therefore, th ...
* UDP,
User Datagram Protocol
In computer networking, the User Datagram Protocol (UDP) is one of the core communication protocols of the Internet protocol suite used to send messages (transported as datagrams in Network packet, packets) to other hosts on an Internet Protoco ...
*
UDP-Lite
* μTP,
Micro Transport Protocol
Comparison of Internet transport layer protocols
Comparison of OSI transport protocols
ISO/IEC 8073/ITU-T Recommendation X.224, "Information Technology - Open Systems Interconnection - Protocol for providing the connection-mode transport service", defines five classes of connection-mode transport protocols designated class 0 (TP0) to class 4 (TP4). Class 0 contains no error recovery and was designed for use on network layers that provide error-free connections. Class 4 is closest to TCP, although TCP contains functions, such as the graceful close, which OSI assigns to the session layer. All OSI connection-mode protocol classes provide expedited data and preservation of record boundaries. Detailed characteristics of the classes are shown in the following table:
There is also a connectionless transport protocol, specified by ISO/IEC 8602/ITU-T Recommendation X.234.
References
Bibliography
*
*
{{Wikiversity , Transport layer
OSI model