TY - JOUR
T1 - Load balancing in dynamic structured peer-to-peer systems
AU - Surana, Sonesh
AU - Godfrey, Brighten
AU - Lakshminarayanan, Karthik
AU - Karp, Richard
AU - Stoica, Ion
N1 - Funding Information:
We thank the authors of Gummadi et al. [12] and Saroiu et al. [23] for making their measurement data available to us. This research was sponsored by National Science Foundation (NSF) under grant number ITR-00225660, by a NSF Career Award under grant number ANI-0133811, and industrial support from Microsoft.
PY - 2006/3
Y1 - 2006/3
N2 - Most P2P systems that provide a DHT abstraction distribute objects randomly among "peer nodes" in a way that results in some nodes having Θ(log N) times as many objects as the average node. Further imbalance may result due to nonuniform distribution of objects in the identifier space and a high degree of heterogeneity in object loads and node capacities. Additionally, a node's load may vary greatly over time since the system can experience continuous insertions and deletions of objects, skewed object arrival patterns, and continuous arrival and departure of nodes. In this paper, we propose an algorithm for load balancing in such heterogeneous, dynamic P2P systems. Our simulation results show that in the face of rapid arrivals and departures of objects of widely varying load, our algorithm improves load balance by more than an order of magnitude for system utilizations as high as 80% while incurring an overhead of only about 6%. We also show that our distributed algorithm performs only negligibly worse than a similar centralized algorithm, and that node heterogeneity helps, not hurts, the scalability of our algorithm. Although many of these results are dependent on the workload, we believe the efficiency and performance improvement demonstrated over the case of no load balancing shows that our technique holds promise for deployed systems.
AB - Most P2P systems that provide a DHT abstraction distribute objects randomly among "peer nodes" in a way that results in some nodes having Θ(log N) times as many objects as the average node. Further imbalance may result due to nonuniform distribution of objects in the identifier space and a high degree of heterogeneity in object loads and node capacities. Additionally, a node's load may vary greatly over time since the system can experience continuous insertions and deletions of objects, skewed object arrival patterns, and continuous arrival and departure of nodes. In this paper, we propose an algorithm for load balancing in such heterogeneous, dynamic P2P systems. Our simulation results show that in the face of rapid arrivals and departures of objects of widely varying load, our algorithm improves load balance by more than an order of magnitude for system utilizations as high as 80% while incurring an overhead of only about 6%. We also show that our distributed algorithm performs only negligibly worse than a similar centralized algorithm, and that node heterogeneity helps, not hurts, the scalability of our algorithm. Although many of these results are dependent on the workload, we believe the efficiency and performance improvement demonstrated over the case of no load balancing shows that our technique holds promise for deployed systems.
KW - Distributed hash table
KW - Dynamic load balancing
KW - Structured peer-to-peer
UR - http://www.scopus.com/inward/record.url?scp=28244485428&partnerID=8YFLogxK
UR - http://www.scopus.com/inward/citedby.url?scp=28244485428&partnerID=8YFLogxK
U2 - 10.1016/j.peva.2005.01.003
DO - 10.1016/j.peva.2005.01.003
M3 - Article
AN - SCOPUS:28244485428
SN - 0166-5316
VL - 63
SP - 217
EP - 240
JO - Performance Evaluation
JF - Performance Evaluation
IS - 3
ER -