Cloud applications are increasingly shifting from large monolithic services to complex graphs of loosely-coupled microservices. Despite the advantages of modularity and elasticity microservices offer, they also complicate cluster management and performance debugging, as dependencies between tiers introduce backpressure and cascading QoS violations. Prior work on performance debugging for cloud services either relies on empirical techniques, or uses supervised learning to diagnose the root causes of performance issues, which requires significant application instrumentation, and is difficult to deploy in practice. We present Sage, a machine learning-driven root cause analysis system for interactive cloud microservices that focuses on practicality and scalability. Sage leverages unsupervised ML models to circumvent the overhead of trace labeling, captures the impact of dependencies between microservices to determine the root cause of unpredictable performance online, and applies corrective actions to recover a cloud service's QoS. In experiments on both dedicated local clusters and large clusters on Google Compute Engine we show that Sage consistently achieves over 93% accuracy in correctly identifying the root cause of QoS violations, and improves performance predictability.
CITATION STYLE
Gan, Y., Liang, M., Dev, S., Lo, D., & Delimitrou, C. (2021). Sage: Practical and scalable ML-driven performance debugging in microservices. In International Conference on Architectural Support for Programming Languages and Operating Systems - ASPLOS (pp. 135–151). Association for Computing Machinery. https://doi.org/10.1145/3445814.3446700
Mendeley helps you to discover research relevant for your work.