Lorenzo Saino, Fastly
This talk explains how Fastly built a distributed health-checking system capable of driving stable traffic allocation, while quickly and accurately identifying failures. The key intuition behind our design is that the common approach of estimating the operational readiness of a service instance based on its state alone leads to inaccurate decisions. Instead, the health of each instance should be evaluated in the context of the whole service: an instance should be classified unhealthy only if its behavior deviates significantly from other instances in a cluster. Our design borrows techniques from machine learning, signal processing and control theory to ensure overall system availability.
Attendees will learn:
- About the challenges involved in health-checking complex services and how to make accurate, timely and stable decisions.
- How health-checking can be abstracted into a tractable mathematical problem that can be effectively solved by applying known tools and techniques from machine learning, signal processing and control theory.
- How to implement such a system practically, what the issues are, and the tradeoffs involved.
Lorenzo Saino, Fastly
Lorenzo Saino is a software engineer at Fastly, where he works on network systems and load balancing problems. Prior to that, he was a PhD student at University College London. His thesis investigated design issues in networked caching systems and he was awarded the Fabrizio Lombardi prize in 2016 for his research.
SREcon18 Americas Open Access Videos Sponsored by
Indeed
Open Access Media
USENIX is committed to Open Access to the research presented at our events. Papers and proceedings are freely available to everyone once the event begins. Any video, audio, and/or slides that are posted after the event are also free and open to everyone. Support USENIX and our commitment to Open Access.
author = {Lorenzo Saino},
title = {Stable and Accurate {Health-Checking} of {Horizontally-Scaled} Services},
year = {2018},
address = {Santa Clara, CA},
publisher = {USENIX Association},
month = mar
}