Misplaced Pages

Transport layer: Difference between revisions

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
Browse history interactively← Previous editContent deleted Content addedVisualWikitext
Revision as of 08:27, 3 September 2015 editDsimic (talk | contribs)Extended confirmed users, Pending changes reviewers, Rollbackers39,664 editsm Reverted edits by 117.211.164.149 (talk) to last version by Guy Harris← Previous edit Latest revision as of 02:26, 18 September 2024 edit undoKvng (talk | contribs)Extended confirmed users, New page reviewers108,347 editsm unpiped links using script. obey engvar. 
(151 intermediate revisions by 90 users not shown)
Line 1: Line 1:
{{short description|Layer in the OSI and TCP/IP models providing host-to-host communication services for applications}}
{{More citations needed|date=October 2015}}
{{Use American English|date = March 2019}}
{{Use mdy dates|date = March 2019}}

]
{{IPstack}} {{IPstack}}
In ], a '''transport layer''' provides end-to-end or host-to-host communication services for applications within a layered architecture of network components and protocols.<ref>RFC 1122, §1.1.3.</ref> The transport layer provides services such as ] ] support, ], ], and ].


In ]ing, the '''transport layer''' is a conceptual division of methods in the ] of protocols in the network stack in the ] and the ]. The protocols of this layer provide end-to-end communication services for applications.{{Ref RFC|1122|rsection=1.1.3}} It provides services such as ], ], ], and ].
Transport layer implementations are contained in both the ] (RFC 1122),<ref>RFC 1122, Requirements for Internet Hosts – Communication Layers, IETF, R. Braden (Editor), October 1989</ref> which is the foundation of the ], and the ] ] of general networking, however, the definitions of details of the transport layer are different in these models. In the ] model the transport layer is most often referred to as '''Layer 4''' or '''L4'''.


The details of implementation and semantics of the transport layer of the ],{{Ref RFC|1122}} which is the foundation of the ], and the ] 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''',<ref>{{cite web|url=https://docs.oracle.com/cd/E19455-01/806-0916/6ja85398m/index.html|work=System Administration Guide, Volume 3|title=Introducing the Internet Protocol Suite}}</ref> while numbered layers are not used in TCP/IP.
The best-known transport protocol is the ] (TCP). It lent its name to the title of the entire ], ''TCP/IP''. It is used for connection-oriented transmissions, whereas the connectionless ] (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. Other prominent protocols in this group are the ] (DCCP) and the ] (SCTP).

The best-known transport protocol of the Internet protocol suite is the ] (TCP). It is used for connection-oriented transmissions, whereas the connectionless ] (UDP) is used for simpler messaging transmissions. TCP is the more complex protocol, due to its ] 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 ] (DCCP) and the ] (SCTP).


{{OSI model}} {{OSI model}}

==Services== ==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: Transport layer services are conveyed to an application via a programming interface to the transport layer protocols. The services may include the following features:<ref>{{Cite web |title=Transport Layer |url=http://103.47.12.35/bitstream/handle/1/4881/659.pdf?sequence=1&isAllowed=y |website=Galgotias University }}</ref>
* ]: It is normally easier for an application to interpret a connection as a ] rather than having to deal with the underlying connection-less models, such as the ] model of the ] (UDP) and of the ] (IP). * ]:<ref>{{Cite web |last=Heena |first=Khera |title=Data Communication and networking |url=http://103.47.12.35/bitstream/handle/1/4881/659.pdf?sequence=1&isAllowed=y |website=Galgotias University |page=9}}</ref> It is normally easier for an application to interpret a connection as a ] rather than having to deal with the underlying connection-less models, such as the ] model of the ] (UDP) and of the ] (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 ]. * 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 ].
* ]: Packets may be lost during transport due to ] and errors. By means of an ], such as a ], the transport protocol may check that the data is not corrupted, and verify correct receipt by sending an ] or ] message to the sender. ] schemes may be used to retransmit lost or corrupted data. * ]: Packets may be lost during transport due to ] and errors. By means of an ], such as a ], the transport protocol may check that the data is not corrupted, and verify correct receipt by sending an ] or ] message to the sender. ] schemes may be used to retransmit lost or corrupted data.
* ]: 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 ], causing a buffer overrun. This can also be used to improve efficiency by reducing ]. * ]: 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 ], causing a buffer overrun. This can also be used to improve efficiency by reducing ].
* ]: ] can control traffic entry into a telecommunications network, so as to avoid ] by attempting to avoid oversubscription of any of the processing or ] capabilities of the intermediate nodes and networks and taking resource reducing steps, such as reducing the rate of sending ]. For example, ]s may keep the network in a congested state; this situation can be avoided by adding congestion avoidance to the flow control, including ]. This keeps the bandwidth consumption at a low level in the beginning of the transmission, or after packet retransmission. * ]: ] can control traffic entry into a telecommunications network, so as to avoid ] by attempting to avoid oversubscription of any of the processing or ] capabilities of the intermediate nodes and networks and taking resource reducing steps, such as reducing the rate of sending ]. For example, ]s may keep the network in a congested state; this situation can be avoided by adding congestion avoidance to the flow control, including ]. This keeps the bandwidth consumption at a low level in the beginning of the transmission, or after packet retransmission.
* ]: ] 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 ] at the same time. It is part of the transport layer in the ], but of the ] in the OSI model. * ]: ] 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 ] at the same time. It is part of the transport layer in the ], but of the ] in the OSI model.


==Analysis== ==Analysis==
The transport layer is responsible for delivering data to the appropriate application process on the host computers. This involves ] of data from different application processes, i.e. forming data packets, and adding source and destination port numbers in the header of each transport layer data packet. Together with the source and destination IP address, the port numbers constitutes a ], i.e. an identification address of the process-to-process communication. In the OSI model, this function is supported by the ]. The transport layer is responsible for delivering data to the appropriate application process on the host computers. This involves ] 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 ], i.e. an identification address of the process-to-process communication. In the OSI model, this function is supported by the ].


Some transport layer protocols, for example TCP, but not UDP, support ]s, i.e. provide ] communication over an underlying packet oriented ] 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. Some transport layer protocols, for example TCP, but not UDP, support ]s, i.e. provide ] over an underlying packet-oriented ] 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. ] by means of ] and ] (ARQ) protocol. The ARQ protocol also provides ], which may be combined with ]. Finally, some transport layer protocols, for example TCP, but not UDP, provide end-to-end reliable communication, i.e. ] by means of ] and ] (ARQ) protocol. The ARQ protocol also provides ], which may be combined with ].


UDP is a very simple protocol, and does not provide virtual circuits, nor reliable communication, delegating these functions to the ] program. UDP packets are called ]s, rather than segments. UDP is a very simple protocol and does not provide virtual circuits, nor reliable communication, delegating these functions to the ] program. UDP packets are called ]s, rather than segments.


TCP is used for many protocols, including ] web browsing and email transfer. UDP may be used for ] and ], since retransmissions are not possible to a large amount of hosts. UDP typically gives higher ] 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. TCP is used for many protocols, including ] web browsing and email transfer. UDP may be used for ]ing and ], since retransmissions are not possible to a large amount of hosts. UDP typically gives higher ] 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.


In many non-IP-based networks, for example ], ] and ], the connection-oriented communication is implemented at network layer 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. Many non-IP-based networks, such as ], ] and ], 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. 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 ], TCP and UDP are the only widely used transport protocols on the Internet.{{sfn|Papastergiou|Fairhurst|Ros|Brunstrom|2017|p=620-621}} To avoid ] intolerance, new transport protocols may mimic the ] of a tolerated protocol, or ] in UDP, accepting some overhead (e.g., due to outer checksums made redundant by inner integrity checks).{{sfn|Papastergiou|Fairhurst|Ros|Brunstrom|2017|p=623-624}} ] takes the latter approach, rebuilding reliable stream transport on top of UDP.{{sfn|Corbet|2018}}


==Protocols== ==Protocols==
This list shows some protocols that are commonly placed in the transport layers of TCP/IP, OSI, ]'s ], ], and ]. This list shows some protocols that are commonly placed in the transport layers of the ], the ], ]'s ], ], and ].


{{Div col||30em}} {{Div col|colwidth=30em}}
* ATP, ] * ATP, ]
* CUDP, ]<ref>{{citation |url=https://www.cs.cornell.edu/zeno/Papers/cyclicudp.pdf |title=Cyclic-UDP: A Priority-Driven Best-Effort Protocol |author=Brian C. Smith |access-date=2020-02-23}}</ref>
* CUDP, ]
* DCCP, ] * DCCP, ]
* FCP, ] * FCP, ]
* IL, ] * IL, ]
* MPTCP, ] * MPTCP, ]
* RDP, ] * NORM, ]
* ]
* RDP, ]
* RUDP, ] * RUDP, ]
* SCTP, ] * SCTP, ]
Line 48: Line 60:
* TCP, ] * TCP, ]
* UDP, ] * UDP, ]
* ] * ]
* µTP, ] * μTP, ]
{{Div col end}} {{div col end}}


== {{Anchor|COMPARISON1}}Comparison of transport layer protocols == === <span class="anchor" id="COMPARISON1"></span><span class="anchor" id="Comparison of transport layer protocols"></span>Comparison of Internet transport layer protocols ===
{| class="wikitable" {| class="wikitable" style="text-align:center"
|- |-
! scope="col" | Feature
! Feature Name
! ] ! scope="col" | ]
! ] ! scope="col" | ]
! ] ! scope="col" | ]
! ] ! scope="col" | ]
! ] ! scope="col" | ]
! ] ! scope="col" | ]
! scope="col" | ]{{efn|RUDP is not officially standardized. There have been no standard-related developments since 1999.}}
! ]
|- |-
| Packet header size | style="text-align:left" | Packet header size
| 8 bytes | 8 bytes
| 8 bytes | 8 bytes
| 20–60 bytes | 20–60 bytes
| 50–90 bytes | 50–90 bytes
| 12 bytes{{efn|Excluding data chunk headers and overhead chunks. Without embedded chunks, an SCTP packet is essentially useless.}}
| 12 bytes
| 12 or 16 bytes
| 14+ bytes<!--Including 8-byte UDP header-->
|-
| style="text-align:left" | Typical data-packet overhead
| 8 bytes
| 8 bytes
| 20 bytes
| ?? bytes
| 44–48+ bytes{{efn|Counted as follows: 12 bytes SCTP header + 16 bytes DATA chunk header or 20 bytes I-DATA chunk header + 16+ bytes SACK chunk. Additional non-data chunks (e.g. AUTH) and/or headers for additional data chunks, which might easily increase the overhead with 50 bytes or more, not counted.}}
| 12 or 16 bytes | 12 or 16 bytes
| 6+ bytes | 14 bytes
|- |-
| Transport layer packet entity | style="text-align:left" | Transport-layer packet entity
| Datagram | Datagram
| Datagram | Datagram
Line 82: Line 103:
| Datagram | Datagram
|- |-
| Connection oriented | style="text-align:left" | Connection-oriented
| {{No}} | {{No}}
| {{No}} | {{No}}
Line 91: Line 112:
| {{Yes}} | {{Yes}}
|- |-
| Reliable transport | style="text-align:left" | Reliable transport
| {{No}} | {{No}}
| {{No}} | {{No}}
Line 100: Line 121:
| {{Yes}} | {{Yes}}
|- |-
| Unreliable transport | style="text-align:left" | Unreliable transport
| {{Yes}} | {{Yes}}
| {{Yes}} | {{Yes}}
Line 109: Line 130:
| {{Yes}} | {{Yes}}
|- |-
| Preserve message boundary | style="text-align:left" | Preserve message boundary
| {{Yes}} | {{Yes}}
| {{Yes}} | {{Yes}}
Line 118: Line 139:
| {{Yes}} | {{Yes}}
|- |-
| style="text-align:left" | Delivery
| Ordered delivery
| Unordered
| {{No}}
| Unordered
| {{No}}
| {{Yes}} | Ordered
| {{Yes}} | Ordered
| Ordered / Unordered
| {{Yes}}
| Unordered
| {{No}}
| Unordered
| {{Yes}}
|- |-
| style="text-align:left" | Data ]
| Unordered delivery
| {{Yes}} | {{Optional}}
| {{Yes}}
| {{No}}
| {{No}}
| {{Yes}}
| {{Yes}}
| {{Yes}}
|-
| Data ]
| Optional
| {{Yes}} | {{Yes}}
| {{Yes}} | {{Yes}}
Line 143: Line 155:
| {{Yes}} | {{Yes}}
| {{Yes}} | {{Yes}}
| Optional | {{Optional}}
|- |-
| Checksum size (bits) | style="text-align:left" | Checksum size
| 16 | 16 bits
| 16 | 16 bits
| 16 | 16 bits
| 16 | 16 bits
| 32 | 32 bits
| 16 | 16 bits
| 16 | 16 bits
|- |-
| Partial ] | style="text-align:left" | Partial ]
| {{No}} | {{No}}
| {{Yes}} | {{Yes}}
Line 163: Line 175:
| {{No}} | {{No}}
|- |-
| Path ] | style="text-align:left" | Path ]
| {{No}} | {{No}}
| {{No}} | {{No}}
Line 170: Line 182:
| {{Yes}} | {{Yes}}
| {{Yes}} | {{Yes}}
| {{dunno}}
| Unsure
|- |-
| ] | style="text-align:left" | ]
| {{No}} | {{No}}
| {{No}} | {{No}}
Line 181: Line 193:
| {{Yes}} | {{Yes}}
|- |-
| ] | style="text-align:left" | ]
| {{No}} | {{No}}
| {{No}} | {{No}}
Line 188: Line 200:
| {{Yes}} | {{Yes}}
| {{Yes}} | {{Yes}}
| {{dunno}}
| Unsure
|- |-
| ] | style="text-align:left" | ]
| {{No}} | {{No}}
| {{No}} | {{No}}
Line 197: Line 209:
| {{Yes}} | {{Yes}}
| {{Yes}} | {{Yes}}
| {{dunno}}
|
|- |-
| Multiple ] | style="text-align:left" | Multiple ]
| {{No}}
| {{No}} | {{No}}
| {{No}} | {{No}}
| {{No}} | {{No}}
| {{Yes}}
| {{Yes}} | {{Yes}}
| {{No}} | {{No}}
| {{No}} | {{No}}
|- |-
| ] | style="text-align:left" | ]
| {{No}} | {{No}}
| {{No}} | {{No}}
Line 217: Line 229:
| {{No}} | {{No}}
|- |-
| Bundling / ] | style="text-align:left" | Bundling / ]
| {{No}} | {{No}}
| {{No}} | {{No}}
Line 224: Line 236:
| {{Yes}} | {{Yes}}
| {{No}} | {{No}}
| {{dunno}}
| Unsure
|} |}
{{notelist}}


== {{Anchor|COMPARISON2}}Comparison of OSI transport protocols == === {{Anchor|COMPARISON2}}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:<ref>{{cite web 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:<ref>{{cite web
| title = ITU-T Recommendation X.224 (11/1995) ISO/IEC 8073 | title = ITU-T Recommendation X.224 (11/1995) ISO/IEC 8073
| url = http://www.itu.int/rec/T-REC-X.224-199511-I/en/ | url = http://www.itu.int/rec/T-REC-X.224-199511-I/en/
| website = Itu.int
}}</ref>
| access-date=2017-01-17
}}</ref>


{| class="wikitable" border="1" {| class="wikitable"
|- |-
! Service ! scope="col" | Service
! TP0 ! scope="col" | TP0
! TP1 ! scope="col" | TP1
! TP2 ! scope="col" | TP2
! TP3 ! scope="col" | TP3
! TP4 ! scope="col" | TP4
|- |-
| Connection oriented network | Connection-oriented network
| {{Yes}} | {{Yes}}
| {{Yes}} | {{Yes}}
Line 270: Line 285:
| {{Yes}} | {{Yes}}
|- |-
| Error Recovery | Error recovery
| {{No}} | {{No}}
| {{Yes}} | {{Yes}}
Line 284: Line 299:
| {{No}} | {{No}}
|- |-
| multiplexing and demultiplexing over a single ] | Multiplexing and demultiplexing over a single ]
| {{No}} | {{No}}
| {{No}} | {{No}}
Line 316: Line 331:
| title = ITU-T Recommendation X.234 (07/1994) ISO/IEC 8602 | title = ITU-T Recommendation X.234 (07/1994) ISO/IEC 8602
| url = http://www.itu.int/rec/T-REC-X.234-199407-I/en/ | url = http://www.itu.int/rec/T-REC-X.234-199407-I/en/
| website = Itu.int
| access-date=2017-01-17
}}</ref> }}</ref>


==References== ==References==
{{reflist}} {{Reflist}}

==Bibliography==
* {{ cite web | url = https://lwn.net/Articles/745590/ | title = QUIC as a solution to protocol ossification | date = 29 January 2018 | last = Corbet | first = Jonathan | work = ] }}
* {{ cite journal | doi = 10.1109/COMST.2016.2626780 | title = De-Ossifying the Internet Transport Layer: A Survey and Future Perspectives | date = 2017 | journal = ] | last1 = Papastergiou | first1 = Giorgos | last2 = Fairhurst | first2 = Gorry | last3 = Ros | first3 = David | last4 = Brunstrom | first4 = Anna | last5 = Grinnemo | first5 = Karl-Johan | last6 = Hurtig | first6 = Per | last7 = Khademi | first7 = Naeem | last8 = Tüxen | first8 = Michael | last9 = Welzl | first9 = Michael | last10 = Damjanovic | first10 = Dragana | last11 = Mangiante | first11 = Simone | volume = 19 | pages = 619–639 | hdl = 2164/8317 | s2cid = 1846371 | hdl-access = free }}


==External links==
{{Wikiversity | Transport layer}} {{Wikiversity | Transport layer}}


] ]
]
]

Latest revision as of 02:26, 18 September 2024

Layer in the OSI and TCP/IP models providing host-to-host communication services for applications
This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.
Find sources: "Transport layer" – news · newspapers · books · scholar · JSTOR (October 2015) (Learn how and when to remove this message)

Four labeled stacked blocks. The blue block labeled "transport" is the second from the top.
The transport layer in the Internet protocol stack.
Internet protocol suite
Application layer
Transport layer
Internet layer
Link layer

In computer networking, the transport layer is a conceptual division of methods in the layered architecture of protocols in the network stack in the Internet protocol suite and the OSI model. 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, which is the foundation of the Internet, and the OSI model 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 (TCP). It is used for connection-oriented transmissions, whereas the connectionless User Datagram Protocol (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 (SCTP).

OSI model
by layer
7.  Application layer
6.  Presentation layer
5.  Session layer
4.  Transport layer
3.  Network layer
2.  Data link layer
1.  Physical layer

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 model of the User Datagram Protocol (UDP) and of the Internet Protocol (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 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 requests 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 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 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 circuits, i.e. provide connection-oriented communication over an underlying packet-oriented datagram 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 (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 datagrams, rather than segments.

TCP is used for many protocols, including HTTP web browsing and email transfer. UDP may be used for multicasting and broadcasting, since retransmissions are not possible to a large amount of hosts. UDP typically gives higher throughput 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, Frame Relay 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 OSI protocol suite, NetWare's IPX/SPX, AppleTalk, and Fibre Channel.

Comparison of Internet transport layer protocols

Feature UDP UDP-Lite TCP Multipath TCP SCTP DCCP RUDP
Packet header size 8 bytes 8 bytes 20–60 bytes 50–90 bytes 12 bytes 12 or 16 bytes 14+ bytes
Typical data-packet overhead 8 bytes 8 bytes 20 bytes ?? bytes 44–48+ bytes 12 or 16 bytes 14 bytes
Transport-layer packet entity Datagram Datagram Segment Segment Datagram Datagram Datagram
Connection-oriented No No Yes Yes Yes Yes Yes
Reliable transport No No Yes Yes Yes No Yes
Unreliable transport Yes Yes No No Yes Yes Yes
Preserve message boundary Yes Yes No No Yes Yes Yes
Delivery Unordered Unordered Ordered Ordered Ordered / Unordered Unordered Unordered
Data checksum Optional Yes Yes Yes Yes Yes Optional
Checksum size 16 bits 16 bits 16 bits 16 bits 32 bits 16 bits 16 bits
Partial checksum No Yes No No No Yes No
Path MTU No No Yes Yes Yes Yes ?
Flow control No No Yes Yes Yes No Yes
Congestion control No No Yes Yes Yes Yes ?
Explicit Congestion Notification No No Yes Yes Yes Yes ?
Multiple streams No No No No Yes No No
Multi-homing No No No Yes Yes No No
Bundling / Nagle No No Yes Yes Yes No ?
  1. RUDP is not officially standardized. There have been no standard-related developments since 1999.
  2. Excluding data chunk headers and overhead chunks. Without embedded chunks, an SCTP packet is essentially useless.
  3. Counted as follows: 12 bytes SCTP header + 16 bytes DATA chunk header or 20 bytes I-DATA chunk header + 16+ bytes SACK chunk. Additional non-data chunks (e.g. AUTH) and/or headers for additional data chunks, which might easily increase the overhead with 50 bytes or more, not counted.

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:

Service TP0 TP1 TP2 TP3 TP4
Connection-oriented network Yes Yes Yes Yes Yes
Connectionless network No No No No Yes
Concatenation and separation No Yes Yes Yes Yes
Segmentation and reassembly Yes Yes Yes Yes Yes
Error recovery No Yes No Yes Yes
Reinitiate connection (if an excessive number of PDUs are unacknowledged) No Yes No Yes No
Multiplexing and demultiplexing over a single virtual circuit No No Yes Yes Yes
Explicit flow control No No Yes Yes Yes
Retransmission on timeout No No No No Yes
Reliable Transport Service No Yes No Yes Yes

There is also a connectionless transport protocol, specified by ISO/IEC 8602/ITU-T Recommendation X.234.

References

  1. ^ R. Braden, ed. (October 1989). Requirements for Internet Hosts -- Communication Layers. Network Working Group. doi:10.17487/RFC1122. STD 3. RFC 1122. Internet Standard 3. Updated by RFC 1349, 4379, 5884, 6093, 6298, 6633, 6864, 8029 and 9293.
  2. "Introducing the Internet Protocol Suite". System Administration Guide, Volume 3.
  3. "X.225 : Information technology – Open Systems Interconnection – Connection-oriented Session protocol: Protocol specification". Archived from the original on February 1, 2021. Retrieved March 10, 2023.
  4. "Transport Layer" (PDF). Galgotias University.
  5. Heena, Khera. "Data Communication and networking" (PDF). Galgotias University. p. 9.
  6. Papastergiou et al. 2017, p. 620-621.
  7. Papastergiou et al. 2017, p. 623-624.
  8. Corbet 2018.
  9. Brian C. Smith, Cyclic-UDP: A Priority-Driven Best-Effort Protocol (PDF), retrieved February 23, 2020
  10. "ITU-T Recommendation X.224 (11/1995) ISO/IEC 8073". Itu.int. Retrieved January 17, 2017.
  11. "ITU-T Recommendation X.234 (07/1994) ISO/IEC 8602". Itu.int. Retrieved January 17, 2017.

Bibliography

Category: