All Internet routers contain buffers to hold packets during times of congestion. Today, the size of the buffers is determined by the dynamics of TCP's congestion control algorithms. To keep link utilization high, a widely used rule-of-thumb states that each link needs a buffer of size B = RTT × C , where RTT is the average round-trip time of a flow passing across the link, and C is the data rate of the link. For example, a 10Gb/s router linecard needs approximately 250ms × 10Gb/s = 2.5Gbits of buffers; and the amount of buffering grows linearly with the line-rate. Such large buffers are challenging for router manufacturers, who must use large, slow, off-chip DRAMS. And queueing delays can be long, have high variance, and may destabilize the congestion control algorithms.
In this thesis we argue that the rule-of-thumb ( B = RTT × C ) is now outdated and incorrect for backbone routers. This is because of the large number of flows (TCP connections) multiplexed together on a single backbone link. Using theory, simulation and experiments on a network of real routers, we show that a link with n long lived flows requires no more than B = ( RTT × C )/ n , for long-lived or short-lived TCP flows.
The consequences on router design are enormous: A 2.5Gb/s link carrying 10,000 flows could reduce its buffers by 99% with negligible difference in throughput; and a 10Gb/s link carrying 50,000 flows requires only 10Mbits of buffering, which can easily be implemented using fast, on-chip SRAM.
Cited By
- Kong Y, Zang H and Ma X Improving TCP Congestion Control with Machine Intelligence Proceedings of the 2018 Workshop on Network Meets AI & ML, (60-66)
- Gao F and Qian H (2016). Efficient, real-world token bucket configuration for residential gateways, IEEE/ACM Transactions on Networking, 24:1, (462-475), Online publication date: 1-Feb-2016.
- Vishwanath A, Sivaraman V and Thottan M (2009). Perspectives on router buffer sizing, ACM SIGCOMM Computer Communication Review, 39:2, (34-39), Online publication date: 31-Mar-2009.
Recommendations
Sizing router buffers
All Internet routers contain buffers to hold packets during times of congestion. Today, the size of the buffers is determined by the dynamics of TCP's congestion control algorithm. In particular, the goal is to make sure that when a link is congested, ...
Sizing router buffers
SIGCOMM '04: Proceedings of the 2004 conference on Applications, technologies, architectures, and protocols for computer communicationsAll Internet routers contain buffers to hold packets during times of congestion. Today, the size of the buffers is determined by the dynamics of TCP's congestion control algorithm. In particular, the goal is to make sure that when a link is congested, ...
Sizing router buffers (redux)
The queueing delay faced by a packet is arguably the largest source of uncertainty during its journey. It therefore seems crucial that we understand how big the buffers should be in Internet routers. Our 2004 Sigcomm paper revisited the existing rule of ...