Download presentation
Presentation is loading. Please wait.
1
PROMISE: Peer-to-Peer Media Streaming Using CollectCast M. Hefeeda, A. Habib, B. Botev, D. Xu, and B. Bhargava ACM Multimedia 2003, November 2003
2
Outline Motivation CollectCast A new application level P2P service PROMISE operation Selecting best peers Rate and data assignment Dynamic switching Simulation results
3
Service Model Video-on-Demand (multiple sources) A peer can request a video from other peers, or operate as a video server. No other streaming methods (e.g., multicast, batch, chaining, or caching) are involved in this paper.
4
Motivation Problems: A sender may failed. The outbound bandwidth of a sender may change. The connections from senders to the receiver may have different network constraints (end-to-end bandwidth, loss, and failure rate). The underlying network topology should also be considered.
5
CollectCast Developed based on “Pastry”. The three main functions: Inferring the underlying network topology and providing performance information (for sender selection) Monitoring the status of peers and connections Dynamically switching while a peer failure or the rate of this peer is degraded
6
PROMISE Sender selection Active sender set Standby sender set Selection algorithm (select “best” sources) Random selection Topology-aware selection End-to-end selection Rate and data assignment Forward Error Correction (FEC) Derive the upper/lower bound rates (required by the selection algorithm) Dynamic switching (fault tolerant)
7
PROMISE operation. : Virtual router. : Receiver : Peer : Candidate peers Internet
8
Selecting best peers. The selection techniques: Random Randomly choose some peers for delivery. Topology-aware Infer the underlying network topology and its characteristics, then consider the goodness of each segment of the path. End-to-end consider the “goodness” of individual paths and the availability of peers.
9
Goodness Segment goodness Loss rate Delay Jitter Available bandwidth Peer goodness Availability (The fraction of time a peer is available for serving) The goodness of all segments comprising the path to the receiver.
10
Topology-Aware Selection(1/3) :The goodness of the segment. : segment weight (the available bandwidth and level of sharing on the segment ) : A binary random variable that depends on the loss rate. :Available bandwidth on. R p : a fixed offered rate.
11
Topology-Aware Selection(2/3) Example: (for P6) b i j = 0.5 R s = 0.25 R p = 0.5
12
Topology-Aware Selection(3/3) : peer goodness Availability of the sender (A p ) ( The fraction of time a peer is available for serving.) The goodness of all segments comprising the path s.t.
13
Illustrative example Example: {P3,P5,P6} =1*0.8+1*0.8+(0.25/0.5)*0.9 =2.05 We can find the peer sets {P2,P3,P6} has the maximum expected rate 2.4 。
14
: The goodness of a peer p. : The fraction of time a peer is available for serving. : path weight : A binary random variable that depends on the loss rate. End-to-End Selection :A fixed offered rate :Available bandwidth on.
15
Illustrative example Example: {P3,P5,P6} =1*0.8+1*0.8+1*0.9 =2.5 We can find the peer sets {P3,P5,P6} and {P1,P2,P3,P5} have the maximum expected rate 2.5 。
16
Rate and data assignment(1/2) Use Forward Error Correction (FEC) We use the notation FEC(α) to indicate that the system can tolerate up to (α-1)% packet loss rate. Ex: FEC(1.25): 25% of packets can be lost. αhas two bounds: α u ; α l, which are the maximum and minimum loss tolerance levels. We use the constraints : R u = α u R 0 and R l = α l R 0 to selection the peers.
17
Rate and data assignment(2/2) Data segments are pre-encoded using FEC(α u ). The lower bound α l is determined by the expected aggregated loss rate. Rate assignment Each peer is assigned an actual sending rate proportional to its offered rate. Data assignment Ex: {P1, P2, P3} is the active set. Let P1, P2, and P3 are assigned the same sending rate. Then P1 will send the first 1/3 of the video, P2 will send the next 1/3 of the video, and P3 will send the remain parts of the video. Problem: This is not “streaming“! Ex: P1 may deliver a 1Mbps video at 333Kbps. Sol: P1 delivers {1, 4, 7, 10, …}, P2 delivers {2, 5, 8, 11, …}, and P3 delivers {3, 6, 9, 12, …}
18
Dynamic switching (1/2) A peer failure is detected in two ways: From the TCP control channel established (e.g., connection reset). If the rate coming from this peer is degraded. Once a failure is detected, the active set is adjusted by replacing the failed peer with new one(s). The replacing method is: Choose the replacement peers using the topology-aware selection from the standby peers. Why not yield a globally optimal solution? The newly chosen set can be totally different from the old one. (require tearing down all of the old connections and establishing new ones.) The topology is partially updated, so we use the information gathered at the beginning of the streaming session.
19
Dynamic switching (2/2) Example: The possible active sets are {P 4, P 6 }, {P 3, P 5, P 6 }, {P 2,P 5, P 6 }, {P 1, P 5, P 6 }, {P 3, P 4, P 5 }, {P 2, P 4, P 5 }, {P 1, P 4, P 5 }, {P 1, P 3, P 4 }, {P 2, P 3, P 4 }, {P 2, P 3, P 6 }, {P 1, P 3, P 6 }, {P 1, P 2, P 4 }, {P 1, P 2, P 6 }, and {P 1, P 2, P 3, P 5 }. Let the active set be {P 2, P 3, P 6 }. If P 2 is now failed, the new active set will be {P 3, P 5, P 6 } or {P 1, P 3, P 6 }.
20
Simulation results (1/5)
21
Simulation results (2/5)
22
Simulation results (3/5)
23
Simulation results (4/5)
24
Simulation results (5/5) ?
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.