Titan: Fair Packet Scheduling for Commodity Multiqueue NICs

Authors: 

Brent Stephens, Arjun Singhvi, Aditya Akella, and Michael Swift, UW-Madison

Abstract: 

The performance of an OS’s networking stack can be measured by its achieved throughput, CPU utilization, latency, and per-flow fairness. To be able to drive increasing line-rates at 10Gbps and beyond, modern OS networking stacks rely on a number of important hardware and software optimizations, including but not limited to using multiple transmit and receive queues and segmentation offloading. Unfortunately, we have observed that these optimizations lead to substantial flow-level unfairness.

We describe Titan, an extension to the Linux networking stack that systematically addresses unfairness arising in different operating conditions. Across both fine and coarse timescales and when NIC queues are undersubscribed and oversubscribed, we find that the Titan can reduce unfairness by 58% or more when compared with the best performing Linux configuration. We also find that improving fairness can lead to a reduction in tail flow completion times for flows in an all-to-all shuffle in a cluster of servers.

Open Access Media

USENIX is committed to Open Access to the research presented at our events. Papers and proceedings are freely available to everyone once the event begins. Any video, audio, and/or slides that are posted after the event are also free and open to everyone. Support USENIX and our commitment to Open Access.

BibTeX
@inproceedings {203243,
author = {Brent Stephens and Arjun Singhvi and Aditya Akella and Michael Swift},
title = {Titan: Fair Packet Scheduling for Commodity Multiqueue {NICs}},
booktitle = {2017 USENIX Annual Technical Conference (USENIX ATC 17)},
year = {2017},
isbn = {978-1-931971-38-6},
address = {Santa Clara, CA},
pages = {431--444},
url = {https://www.usenix.org/conference/atc17/technical-sessions/presentation/stephens},
publisher = {USENIX Association},
month = jul
}

Presentation Audio