As we've just seen, TCP implements flow control to prevent a sender from overwhelming a receiver. This flow control works by allowing only a limited number of TCP segments to be sent before requiring an acknowledgment of receipt.
TCP also implements congestion control methods as part of a network congestion-avoidance scheme. While flow control is vital to prevent overwhelming the receiver, congestion control is essential to prevent overwhelming the network.
One way TCP congestion control works is by allowing only a limited amount of data to be sent before pausing to wait for an acknowledgment of receipt. This data limit is decreased when network congestion is detected. In this way, TCP doesn't try putting more data over the network than the network can handle.
Another way TCP implements congestion control is through the TCP slow start algorithm. This method provides a way for TCP to ramp-up a connection to its full potential, instead of immediately dumping a lot of data on the network all at once.
It works like this—when a new TCP connection is established, only a minimal amount of data is allowed to be sent unacknowledged. When this data is acknowledged, the limit is increased. Each time a new acknowledgment is received, the limit is increased further until packet loss happens or the limit reaches the desired maximum.
The following diagram shows a TCP slow-start in action:
In the preceding diagram, you can see that the Client starts by sending only a little data. Once that data is acknowledged, the Client is willing to send a larger amount of data before requiring another acknowledgment. Once that acknowledgment is received, the Client increases its limit again, and so on.
The slow-start algorithm can cause problems for short-lived connections. In practice, if a connection needs to send only a small amount of data, that connection won't ever reach its full potential. This has caused many protocols to be designed around keeping connections open for longer. For example, it used to be common for an HTTP connection to transmit only one resource. Now it is far more common for an HTTP connection to be held open for additional resources, one after another. This connection reuse avoids the overhead of the TCP three-way handshake and slow start.
In addition to avoiding congestion, TCP also provides methods to increase bandwidth efficiency.