Automatically detecting risky scripts in infrastructure code
Ting Dai, Alexei Karve, et al.
SoCC 2020
Autoscaling is the practice of automatically adding or removing resources for an application deployment to meet performance targets in response to changing workload conditions. However, existing autoscaling approaches typically require expert application and system knowledge to reduce resource costs and performance target violations, thus limiting their applicability. We present MLscale, an application-agnostic, machine learning based autoscaler that is composed of: (i) a neural network based online (black-box) performance modeler, and (ii) a regression based metrics predictor to estimate post-scaling application and system metrics. Implementation results for diverse applications across several traces highlight MLscale's application-agnostic behavior and show that MLscale (i) reduces resource costs by about 41%, on average, compared to the optimal static policy, (ii) is within 14%, on average, of the cost of the optimal dynamic policy, and (iii) provides similar cost-performance tradeoffs, without requiring any tuning, when compared to carefully tuned threshold-based policies.
Ting Dai, Alexei Karve, et al.
SoCC 2020
Muhammad Wajahat, Anshul Gandhi, et al.
IGSC 2016
Alexei Karve, Andrzej Kochut
CLOUD 2013
Tom Chefalas, Jim Doran, et al.
CEWIT 2011