DEV Community

Jonathan Hall
Jonathan Hall

Posted on • Originally published at jhall.io on

What can we learn from the Facebook outage?

If you’re like me, you may not have noticed the Facebook/Instagram/WhatsApp outage first-hand. But you’re probably not like me, and you probably found this outage to be a personal nuisance.

Now that things are returning to normal, Facebook has given us a small glimpse into what happened:

Our engineering teams have learned that configuration changes on the backbone routers that coordinate network traffic between our data centers caused issues that interrupted this communication.

Ah! Human error. Those pesky humans. I hope they learned their lesson.

Not so fast.

It may be easy and tempting to point to the human (or group of humans) who made a configuration error, and call it a day. But at the end of the day, the vast majority of technical failures, be it in IT systems, aircraft accidents, automobile accidens, or burned cupcakes, come down to human error. If we end our investigation there, we’ll never really improve.

So if the human who made the configuration mistake is not to blame, who or what is?

Here are a series of questions you can ask next time you’re faced with this delimma, to put you on the track to a more “human-proof” system:

  • Why did the system allow a human to make an erroneous configuration change?
  • Why was a human error able to have such a broad impact?
  • What safeguards can we put in place to prevent such errors from occurring?
  • What systems can we put in place to detect such errors before they cause a catastrophic failure?
  • What backups can we put in place so that when there’s a similar failure, we can continue to operate?
  • How can we improve the system so that we can detect such failures more quickly in the future?
  • How can we recover from such failures more quickly next time?

I’m sure you can use your imagination to double or tripple this list. The point is: Even when human error is involved (and it usually is), that should never end your investigation, or be considered the root cause. Do a blameless postmortem, and solve every problem twice.


If you enjoyed this message, subscribe to The Daily Commit to get future messages to your inbox.

Heroku

Build apps, not infrastructure.

Dealing with servers, hardware, and infrastructure can take up your valuable time. Discover the benefits of Heroku, the PaaS of choice for developers since 2007.

Visit Site

Top comments (0)

A Workflow Copilot. Tailored to You.

Pieces.app image

Our desktop app, with its intelligent copilot, streamlines coding by generating snippets, extracting code from screenshots, and accelerating problem-solving.

Read the docs

👋 Kindness is contagious

Engage with a sea of insights in this enlightening article, highly esteemed within the encouraging DEV Community. Programmers of every skill level are invited to participate and enrich our shared knowledge.

A simple "thank you" can uplift someone's spirits. Express your appreciation in the comments section!

On DEV, sharing knowledge smooths our journey and strengthens our community bonds. Found this useful? A brief thank you to the author can mean a lot.

Okay