RMX: reliable multicast for heterogeneous networks

Abstract
Although IP Multicast is an effective network primitive for best-effort, large-scale, multi-point communication, many multicast appli- cations such as shared whiteboards, multi-player games and software dis- tribution require reliable data delivery. Building services like reliable se- quenced delivery on top of IP Multicast has proven to be a hard problem. The enormous extent of network and end-system heterogeneity in multi- point communication exacerbates the design of scalable end-to-end reliable multicast protocols. In this paper, we propose a radical departure from the traditional end-to-end model for reliable multicast and instead propose a hybrid approach that leverages the successes of unicast reliability protocols such as TCP while retaining the efficiency of IP multicast for multi-point data delivery. Our approach splits a large heterogeneous reliable multicast session into a number of multicast data groups of co-located homogeneous participants. A collection of application-aware agents—Reliable Multicast proXies (RMXs)—organizes these data groups into a spanning tree using an overlay network of TCP connections. Sources transmit data to their lo- cal group, and the RMX in that group forwards the data towards the rest of the data groups. RMXs use detailed knowledge of application semantics to adapt to the effects of heterogeneity in the environment. To demonstrate the efficacy of our architecture, we have built a prototype implementation that can be customized for different kinds of applications.

This publication has 23 references indexed in Scilit: