Measuring developer productivity IRL: practical tips for platform engineers
What should you measure and how ? Industry experts weight in sharing insights from their experience leading engineering organizations at scale.
September 20, 2024
6 mins
With limited resources and a focus on growth, incident management can seem like a distraction for startups—but it’s essential for building trust and improving your product. This article explores best practices for setting up a lightweight but scalable incident response process that allows you to learn from each incident.
Ship, ship, ship. Faster, better! You’ve heard it: if your first version doesn’t have errors, you’ve released too late. But what are you going to do when your customers run into issues? When your APIs inevitably go down?
A growing startup is a unique place for reliability. You need to focus on finding product-market fit, shipping features, closing deals, and organizing funding rounds. It’s crucial to consolidate your first customers’ trust in your product and your team’s ability to improve it. However, you have very limited capacity to dedicate engineers or budget solely to reliability.
While in the early days it may be easy to get all hands on deck to tackle an incident, you’ll quickly find out it’s not a scalable solution. Incident management at a startup starts as a lean and loose process but with enough structure to let your team develop the skills to get all systems back up quickly and learn how to improve your product and services.
As a startup, it’s tempting to brush off the need for an incident management strategy. There are good arguments for founders to put it off: limited resources, growing teams, and scaling. However, these are precisely the areas where establishing an incident management strategy can improve your execution.
{{cta-demo}}
Mason Jones, Director of Internal Platform at Zapier, has launched reliability programs at several startups. Mason explains that, regarding incidents, “having some lightweight process early on is really critical.” Otherwise, you’ll start running into problems like duplicated efforts, missed checks, and burnout.
You probably don’t need full-blown on-call rotations with several layers of redundancy. But distributing the on-call load across your team is important to prevent burnout. The psychological effect of being “always on” will rapidly impact your team. You don’t want to lose founding team members over preventable issues. It’ll hit them faster than you think, so don’t put it off too long.
Modern on-call solutions like Rootly can be set up within minutes. Gone are the days when you needed an engineer to go through a week of PagerDuty training just so someone could get a push notification. Rootly makes it easy to schedule rotations and allows overrides when needed.
As a startup, you may not need to implement a full observability strategy right away. Setting up alerts can be as simple as receiving an email from a customer about something not working, or adding a heartbeat endpoint to your API. Rootly can monitor both cases with just a few clicks. You can implement more sophisticated instrumentation later, and Rootly will manage that scaling complexity with you.
Incidents are confusing and stressful. They can paralyze your entire team at times. You need all hands on deck to ensure your customers can access their accounts again or process their orders.
However, after your team grows beyond a couple of engineers, it’s unlikely that bringing everyone together to solve an incident will resolve it faster. You’ll end up with people duplicating tasks in panic or forgetting to handle other essential steps.
Instead of rushing everyone to throw things together during an incident, I recommend having a plan for the tasks that need to be covered, assigned to specific roles. You don’t need a fully developed program, but assigning ownership of areas like communications and customer relations will go a long way.
Offering a status page is the simplest and cheapest way to convey transparency to your customers as a startup. Typically, customers doing business with startups expect occasional glitches in availability. Providing a channel where they can check if there’s an existing issue is helpful because it reassures them that incidents aren’t as frequent as they might think.
Status pages at startups should offer enough technical detail to reassure customers that something is being done to resolve the incident as quickly as possible. A generic “We had a problem, we’ll be back soon” message doesn’t cut it—especially if you’re a B2B startup. Build trust by providing enough detail, but avoid overloading the message with unnecessary information.
Using Rootly, you get on-brand and attractive status pages that you can update from Slack during an incident. Rootly also includes automations, such as restoring the status page to green after resolving an incident.
Yes, incidents are annoying and can delay deliveries. It’s tempting to resolve them quickly and refocus on feature development. But every incident is an opportunity to improve your team and processes. Make it a point to take time to understand what went wrong and how to prevent it in the future.
Incidents often reveal flaws in your architecture. While you may patch the system to keep it running smoothly, relying on temporary fixes can only go so far. Track action items, like upgrading a package or adding safeguards to an API, to ensure the issue doesn’t recur.
Incident management often involves many manual steps, like creating a Slack channel, organizing communication, or logging tasks in your tracker. Automate these processes so you can focus on problem-solving and learning after an incident.
Incident management tools like Rootly offer out-of-the-box integrations and patterns based on how leading tech teams handle incidents. Rootly lets you stand on the shoulders of giants, helping you start your reliability practice ahead of competitors.
Rootly gives you the tools you need to handle incidents quickly and smoothly so you can get back to building.