Publication | Open Access
Elastic Symbiotic Scaling of Operators and Resources in Stream Processing Systems
68
Citations
20
References
2017
Year
Cluster ComputingEngineeringComputer ArchitectureStreaming AlgorithmStream Processing SystemsData Streaming ArchitectureStream Processing FrameworksData ScienceSystems EngineeringParallel ComputingStream ProcessingResource UtilizationStreaming EngineElastic Symbiotic ScalingComputer ScienceData Stream ManagementScalable ComputingWater ResourcesEdge ComputingCloud ComputingParallel ProgrammingData StreamsBig Data
Distributed stream processing frameworks are designed to perform continuous computation on possibly unbounded data streams whose rates can change over time. Devising solutions to make such systems elastically scale is a fundamental goal to achieve desired performance and cut costs caused by resource over-provisioning. These systems can be scaled along two dimensions: the operator parallelism and the number of resources. In this paper, we show how these two dimensions, as two symbiotic entities, are independent but must mutually interact for the global benefit of the system. On the basis of this observation, we propose a fine-grained model for estimating the resource utilization of a stream processing application that enables the independent scaling of operators and resources. A simple, yet effective, combined management of the two dimensions allows us to propose ELYSIUM, a novel elastic scaling approach that provides efficient resource utilization. We implemented the proposed approach within Apache Storm and tested it by running two real-world applications with different input load curves. The outcomes backup our claims showing that the proposed symbiotic management outperforms elastic scaling strategies where operators and resources are jointly scaled.
| Year | Citations | |
|---|---|---|
Page 1
Page 1