Transmission Control Protocol (TCP) is a byte-stream[?], connection-oriented[?], reliable delivery transport layer currently documented by IETF RFC 793.
In the TCP/IP model, TCP provides an interface between a network layer below and an application layer above. Applications send 8-bit byte streams to TCP for delivery onto the network. TCP delineates the byte stream into appropriately sized segments, usually defined by a maximum transmission unit[?] (MTU) size used by the data link layer below.
TCP connections contain three phases: connection establishment, data transfer and connection termination. A 3-way handshake is used to establish a connection. A four-way handshake is used to tear-down a connection. During connection establishment, parameters such as sequence numbers and window sizes are initialized to help ensure ordered delivery and robustness respectively.
While it is possible for a pair of end hosts to initiate a connection between themselves simultaneously, typically one end opens a socket[?] and listens passively for a connection from the other. This is commonly referred to as a passive open and it designates the server-side of a connection. The client-side of a connection initiates an active open by sending an initial SYN segment to the server as part of the 3-way handshake. The server-side should respond to a valid SYN request, with a SYN/ACK. Finally, the client-side should respond to the server with an ACK completing the 3-way handshake and connection establishment phase.
During the data transfer phase, a number of key properties determine TCP's reliability and robustness. These include using sequence numbers for ordering received TCP segments and detecting duplicate data, checksums for segment error detection and acknowledgements and timers for detecting and adjusting to loss or delay.
During the TCP connection establishment phase, initial sequence numbers (ISNs) are exchanged between the two TCP speakers. These sequence numbers are used to identify data in the byte stream and are numbers that essentially count bytes. There are always a pair of sequence numbers included in every TCP segment, which are referred to as the sequence number and the acknowlegement number pair. A TCP sender refers to is own sequence number simply as the sequence number, while the TCP sender refers to receiver's sequence number as the acknowlegement number. To maintain reliability, a receiver acknowleges TCP segment data by indicating it has received up to some number of contiguous bytes in the stream. An enhancement to TCP, called selective acknowlegement (SACK), allows a TCP receiver to acknowlege out of order blocks.
Through the use of sequence and acknowledgement numbers, end hosts can properly deliver received segments in the correct byte stream order to a receiving application. Sequence numbers are 32-bit, unsigned numbers, which wrap to zero on the next byte in the stream after 2^32-1. One key to maintaining robustness and security for TCP connections is in the selection of the ISN.
A 16-bit checksum based on the TCP segment header and data is computed by a sender and included in a segment transmission. The TCP receiver recomputes the checksum on the received TCP header and data. If the receiver's computed checksum matches the received checksum, the segment is assumed to have arrived intact and without error.
The TCP checksum is a quite weak check by modern standards: it restricts TCP to being used over links with quite low bit error rates[?] for data in received packets. If TCP was to be redesigned today, it would most probably have a 32-bit CRC specified as an error check instead of the current checksum. The weak checksum problem is usally fixed by adding a CRC or better integrity check at layer 2, below both TCP and IP, such as is used in PPP or the Ethernet frame. However, this doesn't mean that the 16-bit TCP checksum is redundant: remarkably, surveys of Internet traffic have shown that software and hardware errors that introduce errors in packets between CRC-protected hops are common, and that the end-to-end 16-bit TCP checksum catches most of these simple errors.
Acknowlegements for data sent, or lack of acknowlegements are used by senders to implicity interpret network conditions between the TCP sender and receiver. Coupled with timers, TCP senders and receivers can alter the behavior of the flow of data. This is more general referred to as flow control, congestion control and/or congestion avoidance. TCP uses a number of mechanisms to achieve both robustness and high performance. These mechanisms include the use of a sliding window, the slow start algorithm, the congestion avoidance algorithm, the fast retransmit and fast recovery algorithms and more. Enhancing TCP to more effectively handle loss, errors and congestion is an ongoing area of research and standards development.
The connection termination phase uses a a four-way handshake, with each side of the connection terminating independently. Therefore, a typical teardown requires a pair of FIN and ACK segments for each end.
TCP uses the notion of port numbers to identify sending and receiving applications. Each side of the TCP connection has an associated 16-bit unsigned port number assigned to the sending or receiving application. Ports are categorized into three basic categories: well known, registered and dynamic/private. The well known ports are assigned by the Internet Assigned Numbers Authority (IANA) and are typically used by system-level or root processes. Well known applications running as servers and passively listening for connections typically use these ports. Some examples include: FTP (21), TELNET (23), SMTP (25) and HTTP (80). Registered ports are typically used by end user applications as ephemeral source ports when contacting servers, but they can also identify named services that have been registered by a third party. Dynamic/private ports are can also be used by end user applications, but much less commonly so. They typically do not contain any meaning outside of a particular TCP connection.
TCP is fairly complex and evolving protocol. While significant enhancements have been made and proposed over the years, its basic operation has not changed significantly since RFC 793, published in 1981. In 2001 RFC 3168 added explicit congestion notification as an update to 793. In the early 21st century, TCP is typically used in approximately 95% of all Internet packets. Common applications that use TCP include HTTP/HTTPS (world wide web), SMTP/POP3/IMAP (email) and FTP (file transfer). Its widespread use is testimony to the original designers that their creation was exceptionally well done.
However, TCP isn't appropriate for many applications and newer transport layer protocols are being designed and deployed to address some of the inherent weaknesses. For example, real-time applications often do not need and will suffer from the use of TCP's reliable delivery mechanisms. In those types of applications, it is often better to deal with some loss, errors or congestion than try to adjust for them. Example applications that do not typically use TCP include real-time streaming multimedia[?] (such as Internet radio) and some real-time multiplayer games. Any application that doesn't require reliability or that wants to minimize functionality may choose to avoid using TCP. In many cases, the user datagram protocol (UDP) may be used in place of TCP when just application multiplexing services are required.
External Links
- RFC793 (http://www.ietf.org/rfc/rfc793.txt)
- IANA Port Assignments (http://www.iana.org/assignments/port-numbers)
- Sally Floyd's homepage (http://www.icir.org/floyd/)
- John Kristoff's Overview of TCP (http://condor.depaul.edu/~jkristof/technotes/tcp.html)
- When The CRC and TCP Checksum Disagree (http://citeseer.nj.nec.com/stone00when.html)
Common misspelling and questions (FAQ)
ransmission-control-protocol tansmission-control-protocol trnsmission-control-protocol trasmission-control-protocol tranmission-control-protocol transission-control-protocol transmssion-control-protocol transmision-control-protocol transmision-control-protocol transmisson-control-protocol transmissin-control-protocol transmissio-control-protocol transmissioncontrol-protocol transmission-ontrol-protocol transmission-cntrol-protocol transmission-cotrol-protocol transmission-conrol-protocol transmission-contol-protocol transmission-contrl-protocol transmission-contro-protocol transmission-controlprotocol transmission-control-rotocol transmission-control-potocol transmission-control-prtocol transmission-control-proocol transmission-control-protcol transmission-control-protool transmission-control-protocl transmission-control-protoco rtansmission-control-protocol tarnsmission-control-protocol trnasmission-control-protocol trasnmission-control-protocol tranmsission-control-protocol transimssion-control-protocol transmsision-control-protocol transmission-control-protocol transmisison-control-protocol transmissoin-control-protocol transmissino-control-protocol transmissio-ncontrol-protocol transmissionc-ontrol-protocol transmission-ocntrol-protocol transmission-cnotrol-protocol transmission-cotnrol-protocol transmission-conrtol-protocol transmission-contorl-protocol transmission-contrlo-protocol transmission-contro-lprotocol transmission-controlp-rotocol transmission-control-rpotocol transmission-control-portocol transmission-control-prtoocol transmission-control-prootcol transmission-control-protcool transmission-control-protoocl transmission-control-protoclo transmission-control-protoco ttransmission-control-protocol trransmission-control-protocol traansmission-control-protocol trannsmission-control-protocol transsmission-control-protocol transmmission-control-protocol transmiission-control-protocol transmisssion-control-protocol transmisssion-control-protocol transmissiion-control-protocol transmissioon-control-protocol transmissionn-control-protocol transmission--control-protocol transmission-ccontrol-protocol transmission-coontrol-protocol transmission-conntrol-protocol transmission-conttrol-protocol transmission-contrrol-protocol transmission-controol-protocol transmission-controll-protocol transmission-control--protocol transmission-control-pprotocol transmission-control-prrotocol transmission-control-prootocol transmission-control-prottocol transmission-control-protoocol transmission-control-protoccol transmission-control-protocool transmission-control-protocoll 5ransmission-control-protocol rransmission-control-protocol fransmission-control-protocol 6ransmission-control-protocol gransmission-control-protocol 6ransmission-control-protocol yransmission-control-protocol gransmission-control-protocol t4ansmission-control-protocol teansmission-control-protocol tdansmission-control-protocol t5ansmission-control-protocol tfansmission-control-protocol t5ansmission-control-protocol ttansmission-control-protocol tfansmission-control-protocol trqnsmission-control-protocol trwnsmission-control-protocol trznsmission-control-protocol trwnsmission-control-protocol trsnsmission-control-protocol trznsmission-control-protocol trahsmission-control-protocol trabsmission-control-protocol trajsmission-control-protocol trajsmission-control-protocol tramsmission-control-protocol tranwmission-control-protocol tranamission-control-protocol tranzmission-control-protocol tranemission-control-protocol tranxmission-control-protocol tranemission-control-protocol trandmission-control-protocol tranxmission-control-protocol transjission-control-protocol transnission-control-protocol transkission-control-protocol transkission-control-protocol trans,ission-control-protocol transm8ssion-control-protocol transmussion-control-protocol transmjssion-control-protocol transm9ssion-control-protocol transmkssion-control-protocol transm9ssion-control-protocol transmossion-control-protocol transmkssion-control-protocol transmiwsion-control-protocol transmiasion-control-protocol transmizsion-control-protocol transmiesion-control-protocol transmixsion-control-protocol transmiesion-control-protocol transmidsion-control-protocol transmixsion-control-protocol transmiswion-control-protocol transmisaion-control-protocol transmiszion-control-protocol transmiseion-control-protocol transmisxion-control-protocol transmiseion-control-protocol transmisdion-control-protocol transmisxion-control-protocol transmiss8on-control-protocol transmissuon-control-protocol transmissjon-control-protocol transmiss9on-control-protocol transmisskon-control-protocol transmiss9on-control-protocol transmissoon-control-protocol transmisskon-control-protocol transmissi9n-control-protocol transmissiin-control-protocol transmissikn-control-protocol transmissi0n-control-protocol transmissiln-control-protocol transmissi0n-control-protocol transmissipn-control-protocol transmissiln-control-protocol transmissioh-control-protocol transmissiob-control-protocol transmissioj-control-protocol transmissioj-control-protocol transmissiom-control-protocol transmission0control-protocol transmissionpcontrol-protocol transmission[control-protocol transmission-dontrol-protocol transmission-xontrol-protocol transmission-fontrol-protocol transmission-fontrol-protocol transmission-vontrol-protocol transmission-c9ntrol-protocol transmission-cintrol-protocol transmission-ckntrol-protocol transmission-c0ntrol-protocol transmission-clntrol-protocol transmission-c0ntrol-protocol transmission-cpntrol-protocol transmission-clntrol-protocol transmission-cohtrol-protocol transmission-cobtrol-protocol transmission-cojtrol-protocol transmission-cojtrol-protocol transmission-comtrol-protocol transmission-con5rol-protocol transmission-conrrol-protocol transmission-confrol-protocol transmission-con6rol-protocol transmission-congrol-protocol transmission-con6rol-protocol transmission-conyrol-protocol transmission-congrol-protocol transmission-cont4ol-protocol transmission-conteol-protocol transmission-contdol-protocol transmission-cont5ol-protocol transmission-contfol-protocol transmission-cont5ol-protocol transmission-conttol-protocol transmission-contfol-protocol transmission-contr9l-protocol transmission-contril-protocol transmission-contrkl-protocol transmission-contr0l-protocol transmission-contrll-protocol transmission-contr0l-protocol transmission-contrpl-protocol transmission-contrll-protocol transmission-controo-protocol transmission-controk-protocol transmission-contro,-protocol transmission-controp-protocol transmission-contro.-protocol transmission-controp-protocol transmission-contro;-protocol transmission-contro.-protocol transmission-control0protocol transmission-controlpprotocol transmission-control[protocol transmission-control-0rotocol transmission-control-orotocol transmission-control-lrotocol transmission-control--rotocol transmission-control-;rotocol transmission-control--rotocol transmission-control-[rotocol transmission-control-;rotocol transmission-control-p4otocol transmission-control-peotocol transmission-control-pdotocol transmission-control-p5otocol transmission-control-pfotocol transmission-control-p5otocol transmission-control-ptotocol transmission-control-pfotocol transmission-control-pr9tocol transmission-control-pritocol transmission-control-prktocol transmission-control-pr0tocol transmission-control-prltocol transmission-control-pr0tocol transmission-control-prptocol transmission-control-prltocol transmission-control-pro5ocol transmission-control-prorocol transmission-control-profocol transmission-control-pro6ocol transmission-control-progocol transmission-control-pro6ocol transmission-control-proyocol transmission-control-progocol transmission-control-prot9col transmission-control-proticol transmission-control-protkcol transmission-control-prot0col transmission-control-protlcol transmission-control-prot0col transmission-control-protpcol transmission-control-protlcol transmission-control-protodol transmission-control-protoxol transmission-control-protofol transmission-control-protofol transmission-control-protovol transmission-control-protoc9l transmission-control-protocil transmission-control-protockl transmission-control-protoc0l transmission-control-protocll transmission-control-protoc0l transmission-control-protocpl transmission-control-protocll transmission-control-protocoo transmission-control-protocok transmission-control-protoco, transmission-control-protocop transmission-control-protoco. transmission-control-protocop transmission-control-protoco; transmission-control-protoco. transmyssion-control-protocol transmisson-control-protocol transmision-control-protocol yransmission-control-protocol tyransmission-control-protocol transmission-control-protocolsBut this seems classes and appellations. The character of Caesar and that of strictest and most limited sense of the word; but in a different them. The one produces love, the other esteem: the one is character in a friend; the other we should be ambitious of in temperance or industry or frugality, may be somewhat different them entirely of a different species. And, indeed, we may produce not, all of them, the same kind of approbation. Good love and affection. [Footnote: Love and esteem are nearly the same passion, and arise as communicate pleasures. But where this pleasure is severe and impression, or where it produces any degree of humility and awe; is more properly denominated esteem than love. Benevolence degree. There seems to be still a stronger mixture of pride in difficulty to one, who studied accurately the passions. All these from a very curious subject of speculation, but are wide for our general, what qualities are a subject of praise or of censure, which they excite. It is evident, that whatever is.