300 likes | 457 Views
MediaNet : User-defined Adaptive Scheduling for Streaming Data. Michael Hicks Adithya Nagarajan University of Maryland. Robbert van Renesse Cornell University. Motivation. Multi-user streaming data applications Sources Sensor reports Movies Live video or audio Weather reports
E N D
MediaNet: User-defined Adaptive Scheduling for Streaming Data Michael Hicks Adithya Nagarajan University of Maryland Robbert van Renesse Cornell University
Motivation • Multi-user streaming data applications • Sources • Sensor reports • Movies • Live video or audio • Weather reports • Stock quotes • Support Quality of Service (QoS) • Application-specific metrics • Fair and efficient sharing of resources • Situations • Military • Disaster • Home network
MediaNet • Adaptive • Schedules flows using available resources • Adapts to loads not under its control • User-directed • Adaptations are directed by users, based on relative preferences and user priority • Comprehensive • Global view of the network, accounting for overall network utilization, and per-user utility
MediaNet Architecture Video source User’s desired stream & adaptation prefs schedules Global scheduling service Video player subscribe feedback Video description, location, & resource info publish
Streaming Computations • Continuous Media Network (CMN) • Directed acyclic graph of operations • frame droppers, transcoders, compressors and decompressors, filters, aggregators, etc. • User specification • One or more CMN’s, each with associated utility value • Goal: Maximize users’ utility while utilizing the network efficiently
Operations Op frm1 … … frmn Frame size Interval • Other attributes • Fixed location? • Transitions only?
Example User Specification Utility CMN Vid Prio* User 1.0 pcS pcD Vid Prio* Drop B Prio* User 0.3 pcS pcD Vid Prio* Drop PB Prio* User 0.1 pcS pcD
Global Scheduling Service • Schedules each user specification on the actual network • Locates each operation on a node • Inserts send and receive operations between nodes; can have varying transport attributes • Scheduling choices based on current network resources (i.e. operates on-line)
Global Scheduling Algorithm • Simulated annealing technique • Cost function for network configurations • Maximize minimum utility for all users, plus • Optimize individual user utilities above minimum • Use best-cost configuration at these utilities • Cost function • Relates resource cost of a configuration to the total resources available (CPU, bandwidth)
Creating Configurations • Gather all user specs at utility u, combine them, and partition into distinct trees • For each tree • Calculate network “shortest” paths • Actually, most bandwidth-plentiful paths • Find “best” placement of operations to nodes
Example: Creating Config Vid1 Prio* User1 Vid2 Prio* User2 pc1 pc2 pc5 pc4 Vid1 Prio* User3 Vid2 Prio* User4 pc1 pc2 pc7 pc8 Vid1 Prio* User5 5 user specifications, utility 1.0 pc1 pc8
Example: Creating Config Vid1 Prio* User1 Vid2 Prio* User2 pc1 pc2 pc5 pc4 User3 User4 pc7 pc8 User5 Combining the specs pc8
Example: Scheduling pc1 pc5 pc7 300 150 300 300 pc3 pc4 300 150 300 pc2 pc6 pc8 300 1. Initial network conditions
Example: Scheduling pc1 pc5 pc7 v1 u1 u3 300 150 300 300 pc3 pc4 p* p* 300 150 300 pc2 pc6 pc8 300 u5 2. Scheduling the 1st tree
Example: Scheduling pc1 pc5 pc7 v1 u1 u3 150 0 150 150 pc3 pc4 p* p* 300 150 150 pc2 pc6 pc8 300 u5 3. Adjusting edge weights
Example: Scheduling pc1 pc5 pc7 v1 u1 u3 150 0 150 150 pc3 pc4 p* p* 300 150 150 pc2 pc6 pc8 300 u2 v2 p* u5 u4 4. Scheduling the 2nd tree
Prototype Implementation • Global scheduling service • implemented on a single node • eventually hierarchical • Local, per-node schedulers • monitor and report available bandwidth; eventually CPU + memory usage • implement local CMNs • Global scheduler reconfigures schedules on-line
Local Scheduling • Implement the CMN given by the GS • Must correctly reconfigure on-line • Report monitoring info back to GS • Implemented in Cyclone • Type-safe, C-like language • One component per operation, dynamically reconfigurable • Current uses TCP for send/receive • Other transports possible/useful
Monitoring • Monitor available bandwidth • Keep track of TCP throughput, attempted vs. actual bandwidth • Report to global scheduler when • attempted ≠ actual bandwidth (i.e. at peak) • after a regular timeout • Too pessimistic • “creep” bandwidth estimate additively to optimistically attempt higher utility configs
On-line Reconfiguration • New configuration is applied in parallel with the current configuration • Old operations are “flushed” along the dataflow path • New operations are enabled when all old ones are flushed on a particular node • Challenges • Rapid reconfiguration • Low disruption to stream
Experiments • Conducted on 8 850 MHz PIII’s, 512 MB RAM, 100 Mb/s Ethernet, RedHat Linux 7.1 using a “bowtie” topology:
Single-flow Performance Comparison No adaptation Priority-based frame dropping Local, proactive frame dropping MediaNet
Multi-User Performance B frame dropping op
Multi-User Performance B frame dropping op
Related Work • Layered Multicast • In-network stream processors • MEGA, Active Nets • Flow planning systems • Ninja, Darwin, CANS, End-to-End Paths, Conductor, PATHS, Choi et al. • Reservation-based QoS • OMEGA
Future Work • Hierarchy of global schedulers • Better scalability • Scaling user utilities • Based on user priority and resource usage • Enforces fairness • Better on-line monitoring • More experiments • Real wireless • Simulation for larger scenarios
Conclusions • Application-specific QoS via user specs • High network utilization and per-user utility via global scheduling: • Share resources between flows in a multicast-like manner, but generalized to CMNs • Utilize multiple, redundant paths • Intelligently place operations to reduce network utilization • Adapts to resource availabilities on-line
For More Information Papers, Software at http://www.cs.umd.edu/projects/medianet