140 likes | 152 Views
The Internet Congestion Manager (CM) is an end-system architecture designed to handle congestion and manage multiple flows concurrently. It abstracts congestion-related information into a single location, allowing adaptive applications to learn and adapt using the CM API. The CM architecture includes congestion controllers, schedulers, responders, and more, offering a comprehensive solution for congestion management tasks. Research questions explore aggregation, feedback frequency, deployment issues, and more.
E N D
The Internet Congestion Manager Hari Balakrishnan MIT LCS http://kendall.lcs.mit.edu/
Motivation • Increasing number of concurrent flows • E.g., Web, conferencing apps,... • Increasing number of non-TCP apps • E.g., conferencing, games, device networks • Emergence of “unresponsive” flows • E.g., “Web accelerators” CM: An end-system architecture for congestion management
Concurrent Flows • Compete, rather than cooperate for resources • N “slow starts,” aggressive behavior on congestion • No shared state learning • Why not lump them all together? • Coupling between different streams • Application-specific (e.g., P-HTTP) CM abstracts all congestion-related information into one location
Adaptive Applications • Layering makes it remarkably hard for applications to learn! • E.g., TCP hides bandwidth information • Key problem: API design • Application-Level Framing (ALF) • Put the application in control of key decisions
Per-host statistics Congestion Manager What We Really Want HTTP Audio Video1 Video2 TCP1 TCP2 UDP IP All congestion management tasks performed in CM Apps learn and adapt using API
CM API • State maintenance • cm_open(), cm_close(), cm_mtu() • Transmission • Notification • Querying • cm_query(&rate, &srtt); • Put in loss rate etc. too
App send() cmapp_send() cm_request() CM IP Transmission API • Callback-based send • Buffered-send
Transmission API (cont.) • Request API: asynchronous sources while (some_event) { get_data(); send(); } • Synchronous sources do_every_t_ms { get_data(); send(); } • Solution: cmapp_update(rate, srtt) callback
Notification API • Application hints • cm_update(nsent, nrecd, lossmode, rtt) • IP output calls cm_notify(nsent) on every transmit • At the receiver • Hints notification to apportion bandwidth
Applications Applications Congestion Controller Hints dispatch CM protocol Congestion detector Scheduler Responder Prober Receiver Sender The CM Architecture API API
Details • Congestion controller • Window-based AIMD with traffic shaping • Exponential aging when feedback low • Plug in other algorithms (per-macroflow!) • Scheduler • Weighted RR, H-FSC • Plug in other algorithms (per-macroflow!) • Prober-responder uses CM protocol
Status • Implementation in progress (Linux) • Web server + TCP/CM • cmapp_send() used by TCP • cmapp_update(rate, srtt) used by httpd • Layered audio server • Modified browsers • Extensive simulation results • Paper at SIGCOMM ‘99
Research Questions • Aggregation: per-host, per-subnet,… • Handling diff-serv (split macroflow) • Feedback frequency analysis • “Proxy” hosts • End-host policing • More applications
Deployment Issues • In the long-term, change senders and receivers to use the CM • In the short-term, sender-only changes • CM protocol and headers negotiable ==> incremental deployment