Chapter 7. Scalability
Some of the best programming is done on paper, really. Putting it into the computer is just a minor detail.1
Max Kanat-Alexander, Code Simplicity: The Fundamentals of Software
In the summer of 2016, I joined a small company that digitized the kind of forms and miscellaneous paperwork that government bureaucracies are known and loved for. The state of their core application was pretty typical of early-stage startups, so we got to work and, by that fall, had managed to containerize it, describe its infrastructure in code, and fully automate its deployment.
One of our clients was a small coastal city in southeastern Virginia, so when Hurricane Matthew—the first Category 5 Atlantic hurricane in nearly a decade—was forecast to make landfall not far from there, the local officials dutifully declared a state of emergency and used our system to create the necessary paperwork for citizens to fill out. Then they posted it to social media, and a million people all logged in at the same time.
When the pager went off, the on-call checked the metrics and found that aggregated CPU for the servers was pegged at 100% and that hundreds of thousands of requests were timing out.
So we added a zero to the desired server count, created a “to-do” task to implement autoscaling, and went back to our day. Within 24 hours, the rush had passed, so we scaled the servers in.
What did we learn from this, other than the benefits of autoscaling?2
First, it underscored the fact that without ...
Get Cloud Native Go, 2nd Edition now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.