frontpage.
newsnewestaskshowjobs

Made with ♥ by @iamnishanth

Open Source @Github

fp.

Open in hackernews

Root cause analysis? You're doing it wrong

https://entropicthoughts.com/root-cause-analysis-youre-doing-it-wrong
49•davedx•2d ago
Recent and related: https://news.ycombinator.com/item?id=45547079

Comments

kqr•2d ago
Author here. Please note this is an early draft/stream-of-consciousness. Feel free to read and share anyway but my actual published articles hold a higher standard!
maybelsyrup•1h ago
I caught your related comments and eventual link to this post in another HN thread earlier this week and really liked them / it. I'm glad you posted it by itself!
tptacek•1h ago
Some of the same thoughts in Richard Cook, which was a brain-altering read for me:

https://how.complexsystems.fail/

wrs•1h ago
For a deeper dive there’s a somewhat old but excellent book on most of these points called Normal Accidents. [0]

[0] https://en.wikipedia.org/wiki/Normal_Accidents

Waterluvian•1h ago
Hah #7 really hits home. Every RCA I’ve been a part of always ends up pointing to systemic failures in the org at the top level, because walking the tree always leads there. You can’t blame any one person or system for a failure in isolation. It’s usually some form of, “this is ultimately a consequence of miscalibrating risk associated to business/financial decisions.”

I forget where I heard this but, “you manage risk, but risk cannot be managed.” Ie. there is no terminal state where it’s been “solved.” It’s much like “culture of safety.”

bombcar•1h ago
I think #7 strikes (but barely misses) the point - root cause analysis is not root blame analysis- but we often combine them in our mind.
growse•13m ago
This paper so affected me that I scrapped a talk I was writing three days ahead of an (internal) conference and wrote a talk about this paper instead!
bluGill•1h ago
Root cause works better if you can come back next time the same thing happens and find a different root cause to fix. keep repeating until the problem doesn't happen enough to care anymore.

If the result/accident is too bad though you need to find all the different faults and mitigate as manyias possible the first time.

gtirloni•1h ago
I recommend attending the next STAMP Workshop offered by MIT if you have a chance: https://psas.scripts.mit.edu/home/stamp-workshops
jph•1h ago
Thanks for the article and shoutout - CAST is great and I use it extensively with tech teams.

Causal Analysis based on Systems Theory - my notes - https://github.com/joelparkerhenderson/causal-analysis-based...

The full handbook by Nancy G. Leveson at MIT is free here: http://sunnyday.mit.edu/CAST-Handbook.pdf

gmuslera•1h ago
Not all problems (and systems) are alike. And probably simple approaches like Occam's Razor will work good enough with most. But the remaining 10% will need deeper digging into more data and correlations.
opwieurposiu•1h ago
I feel like half the time issues are caused by adding some stupid feature that nobody really wants, but makes it in anyways because the incentive is to add features, not make good software.

People rarely react well if you tell them "Hey this feature ticket you made is poorly conceived and will cause problems, can we just not do it?" It is easier just to implement whatever it is and deal with the fallout later.

CobrastanJorji•55m ago
Many years ago, I worked at Amazon, and it was at the time quite fond of the "five whys" approach to root cause analysis: say what happened, ask why that happened, ask why that in turn happened, and keep going until you get to some very fundamental problem.

I was asked to write up such a document for an incident where our team had written a new feature which, upon launch, did absolutely nothing. Our team had accidentally mistyped a flag name on the last day before we handed it to a test team, the test team examined the (nonfunctional) tool for a few weeks and blessed it, and then upon turning it on, it failed to do anything. My five whys document was most about "what part of our process led to a multiweek test effort that would greenlight a tool that does nothing that it is required to do."

I recall my manager handing the doc back to me and saying that I needed to completely redo it because it was unacceptable for us to blame another team for our team's bug, which is how I learned that you can make a five why process blame any team you find convenient by choosing the question. I quit not too long after that.

sanman8119•32m ago
A very relatable experience, lot of pressure to stop the Whys at the dev team and not question larger leadership or organizational moves
hshdhdhehd•26m ago
Interesting one.

My first thought is why is rolling out a new system to prod that is not used yet an incident? I dont think "being in prod" is sufficient. There should be tiers of service and a brand new service should not be on a tier where it having teething issues is an incident.

> what part of our process led to a multiweek test effort that would greenlight a tool that does nothing that it is required to do

would be interested to see the doc, but imagine you'd branch off the causes, one branch of the tree is: UAT didnt pick up the bug. why didn't UAT pick up the bug? .... (you'd need that teams help).

I think that team would have something that is a contributing cause. You shouldn't rely on UAT to pick up a bug in a released product. However just because it is not a root cause doesnt mean it shouldn't be addressed. Today's contributing cause can be tomorrow's root cause!

So yeah yiu dont blame another team but you also dont shield another team from one of their systems needing attention! The wording matters alot though.

The way you worded the question seems a little loaded. But you may be paraphrasing? 5 whys are usually more like "Why did they papaya team not detect the bug before deployment?"

Whereas

> what part of our process led to a multiweek test effort that would greenlight a tool that does nothing that it is required to do

Is more emotive. Sounds like a cross examiners question which isn't the vibe you'd want to go for. 5 whys should be 5 drys. Nothing spicy!

NikolaNovak•16m ago
That's how we do it - there are "branches" to most of our RCAs, and in fact, we have separate sections for root cause analysis (things which directly or indirectly contribute to incident, which are a branched / fractal 5 whys) and lessons learned (things which did not necessarily contribute to incident but which upon reflection we can do better - frequently incident management or communication or reporting or escalation etc).

It took a while for all the teams to embrace the rca process without fear and finger pointing, but now that it's trusted and accepted, problem management stream / rca process probably the healthiest / best viewed of our streams and processes :-)

BeetleB•13m ago
My litmus test for these types of processes: If root causes like "Inflexible with timelines", or "Incentives are misaligned (e.g. prioritizing career over quality)" are not permitted, the whole process is a waste of time.

Edit: You can see others commenting on precisely this. Examples:

https://news.ycombinator.com/item?id=45573027

https://news.ycombinator.com/item?id=45573101

https://news.ycombinator.com/item?id=45572561

https://news.ycombinator.com/item?id=45572561

grogers•3m ago
Usually another team's failure is covered by their own independent report. That simplifies creating the report since you don't need to collaborate closely, but also prevents shifting the blame on to anyone else (because really, both teams had failures they should have caught independently). E.g. as the last why:

Why did the testing team not catch that the feature was not functional?

This is covered by LINK

captainkrtek•46m ago
At a large cloud provider I held a role for a bit in the “safety” organization that was tasked with developing better understanding of our incidents, working on tooling to protect systems, and so on.

A few problems I faced:

- culturally a lack of deeper understanding or care around “safety” topics. Forces that be inherently are motivated by launching features and increasing sales, so more often than not you could write an awesome incident retro doc and just get people who are laser focused on the bare minimum of action items.

- security folks co-opting the safety things, because removing access to things can be misconstrued to mean making things safer. While somewhat true, it also makes doing jobs more difficult if not replaced with adequate tooling. What this meant was taking away access and replacing everything with “break glass” mechanisms. If your team is breaking glass every day and ticketing security, you’re probably failing to address both security and safety..

- related to the last point, but a lack of introspection as to the means of making changes which led to the incident. For example: user uses ssh to run a command and ran the wrong command -> we should eliminate ssh. Rather than asking why was ssh the best / only way the user could affect change to the system? Could we build an api for this with tooling and safeguards before cutting off ssh?

hshdhdhehd•38m ago
Please keep working on that piece I think it will be very useful for incident reviewers.

Someone said the quiet part loud! :

"""

Common circumstances missing from accident reports are:

Pressures to cut costs or work quicker,

Competing requests for colleagues,

Unnecessarily complicated systems,

Broken tools,

Biological needs (e.g. sleep or hunger),

Cumbersome enforced processes,

Fear of being consequences of doing something out of the ordinary, and

Shame of feeling in over one’s head.

"""

exmadscientist•25m ago
I agree with a lot of the statements at the top of the article, but some of them are just nonsense. This one, in particular:

> If we analyse accidents more deeply, we can get by analysing fewer accidents and still learn more.

Yeah, that's not how it works. The failure modes of your system might be concentrated in one particularly brittle area, but you really need as much breadth as you can get: the bullets are always fired at the entire plane.

> An accident happens when a system in a hazardous state encounters unfavourable environmental conditions. We cannot control environmental conditions, so we need to prevent hazards.

I mean, I'm an R&D guy, so my experience is biased, but... sometimes the system is just broke and no amount of saying "the system is in a hazardous state" can paper over the fact that you shipped (or, best-case, stress-tested) trash. You absolutely have to run these cases through the failure analysis pipeline, there's no out there, but the analysis flow looks a bit different for things that should-have worked versus things that could-never-have worked. And, yes, it will roll up on management, but... still.

NanoChat – The best ChatGPT that $100 can buy

https://github.com/karpathy/nanochat
594•huseyinkeles•5h ago•94 comments

Dutch government takes control of Chinese-owned chipmaker Nexperia

https://www.cnbc.com/2025/10/13/dutch-government-takes-control-of-chinese-owned-chipmaker-nexperi...
163•piskov•11h ago•89 comments

First device based on 'optical thermodynamics' can route light without switches

https://phys.org/news/2025-10-device-based-optical-thermodynamics-route.html
61•rbanffy•4d ago•8 comments

Why did containers happen?

https://buttondown.com/justincormack/archive/ignore-previous-directions-8-devopsdays/
37•todsacerdoti•9h ago•34 comments

Show HN: SQLite Online – 11 years of solo development, 11K daily users

https://sqliteonline.com/
278•sqliteonline•8h ago•106 comments

Don't Be a Sucker (1943) [video]

https://www.youtube.com/watch?v=vGAqYNFQdZ4
9•surprisetalk•46m ago•0 comments

Root cause analysis? You're doing it wrong

https://entropicthoughts.com/root-cause-analysis-youre-doing-it-wrong
49•davedx•2d ago•21 comments

Abstraction, not syntax

https://ruudvanasseldonk.com/2025/abstraction-not-syntax
29•unripe_syntax•12h ago•2 comments

JIT: So you want to be faster than an interpreter on modern CPUs

https://www.pinaraf.info/2025/10/jit-so-you-want-to-be-faster-than-an-interpreter-on-modern-cpus/
23•pinaraf•1d ago•1 comments

Strudel REPL – a music live coding environment living in the browser

https://strudel.cc
25•birdculture•2h ago•5 comments

JSON River – Parse JSON incrementally as it streams in

https://github.com/rictic/jsonriver
112•rickcarlino•5d ago•55 comments

Modern iOS Security Features – A Deep Dive into SPTM, TXM, and Exclaves

https://arxiv.org/abs/2510.09272
16•todsacerdoti•2h ago•0 comments

Scaling request logging with ClickHouse, Kafka, and Vector

https://www.geocod.io/code-and-coordinates/2025-10-02-from-millions-to-billions/
77•mjwhansen•5d ago•11 comments

Optery (YC W22) – Hiring Tech Lead with Node.js Experience (U.S. & Latin America)

https://www.optery.com/careers/
1•beyondd•4h ago

Android's sideloading limits are its most anti-consumer move

https://www.makeuseof.com/androids-sideloading-limits-are-anti-consumer-move-yet/
443•josephcsible•5h ago•260 comments

CRDT and SQLite: Local-First Value Synchronization

https://marcobambini.substack.com/p/the-secret-life-of-a-local-first
39•marcobambini•4d ago•7 comments

Software update bricks some Jeep 4xe hybrids over the weekend

https://arstechnica.com/cars/2025/10/software-update-bricks-some-jeep-4xe-hybrids-over-the-weekend/
240•gloxkiqcza•6h ago•170 comments

Reverse Engineering a 1979 Camera's Spec

https://blog.mano.lol/posts/film/
13•manoloesparta•2h ago•2 comments

Spotlight on pdfly, the Swiss Army knife for PDF files

https://chezsoi.org/lucas/blog/spotlight-on-pdfly.html
287•Lucas-C•12h ago•86 comments

American solar farms

https://tech.marksblogg.com/american-solar-farms.html
175•marklit•11h ago•203 comments

Roger Dean – His legendary artwork in gaming history (Psygnosis)

https://spillhistorie.no/2025/10/03/legends-of-the-games-industry-roger-dean/
49•thelok•6h ago•10 comments

Smartphones and being present

https://herman.bearblog.dev/being-present/
167•articsputnik•6h ago•105 comments

Matrices can be your friends (2002)

https://www.sjbaker.org/steve/omniv/matrices_can_be_your_friends.html
109•todsacerdoti•10h ago•82 comments

More random home lab things I've recently learned

https://chollinger.com/blog/2025/10/more-homelab-things-ive-recently-learned/
170•otter-in-a-suit•1w ago•86 comments

Environment variables are a legacy mess: Let's dive deep into them

https://allvpv.org/haotic-journey-through-envvars/
183•signa11•4h ago•136 comments

The Sveriges Riksbank Prize in Economic Sciences in Memory of Alfred Nobel 2025

https://www.nobelprize.org/prizes/economic-sciences/2025/summary/
108•k2enemy•9h ago•148 comments

Ancient Patagonian hunter-gatherers took care of their injured and disabled

https://phys.org/news/2025-10-ancient-patagonian-hunter-disabled.html
56•pseudolus•6d ago•61 comments

MPTCP for Linux

https://www.mptcp.dev/
97•SweetSoftPillow•11h ago•18 comments

Programming in Assembly Is Brutal, Beautiful, and Maybe Even a Path to Better AI

https://www.wired.com/story/programming-assembly-artificial-intelligence/
39•fcpguru•2h ago•9 comments

AWS Service Availability Updates

https://aws.amazon.com/about-aws/whats-new/2025/10/aws-service-availability/
12•dabinat•1h ago•0 comments