<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>Forem: Jordan</title>
    <description>The latest articles on Forem by Jordan (@itzdaninja).</description>
    <link>https://forem.com/itzdaninja</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F2186912%2F13413c2d-2d90-4d1d-9afe-d446f2102044.jpg</url>
      <title>Forem: Jordan</title>
      <link>https://forem.com/itzdaninja</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/itzdaninja"/>
    <language>en</language>
    <item>
      <title>Reference Architectures Are Lying to You</title>
      <dc:creator>Jordan</dc:creator>
      <pubDate>Sat, 09 May 2026 18:57:22 +0000</pubDate>
      <link>https://forem.com/itzdaninja/reference-architectures-are-lying-to-you-579n</link>
      <guid>https://forem.com/itzdaninja/reference-architectures-are-lying-to-you-579n</guid>
      <description>&lt;p&gt;Every cloud provider has one. Every major consultancy sells one. &lt;br&gt;
Every conference talk ends with one on the final slide.&lt;/p&gt;

&lt;p&gt;Reference architectures are everywhere. And most of them are making your platform worse.&lt;/p&gt;

&lt;h2&gt;
  
  
  The problem with reference architectures
&lt;/h2&gt;

&lt;p&gt;A reference architecture is a idealised blueprint for how a system should be structured. In theory, it gives teams a proven starting point, reduces decision fatigue, and encodes best practices from organisations that have already solved the hard problems.&lt;/p&gt;

&lt;p&gt;In practice, most organisations use them wrong. They treat the reference architecture as the destination rather than the starting point. They adopt the full stack because the diagram says so, not because they have validated that each component solves a problem they actually have. They optimise for looking like the reference architecture rather than optimising for what their developers actually need.&lt;/p&gt;

&lt;p&gt;The result is platforms that are architecturally impressive and operationally painful. Teams running service meshes they do not need. Organisations operating multi-cluster Kubernetes setups at a scale that does not justify the overhead. Platform teams spending more time maintaining the architecture than delivering value through it.&lt;/p&gt;

&lt;h2&gt;
  
  
  Where reference architectures come from
&lt;/h2&gt;

&lt;p&gt;It is worth understanding what a reference architecture actually represents before adopting one.&lt;/p&gt;

&lt;p&gt;A cloud provider reference architecture represents what is possible on that provider's platform, optimised for showcasing their services. It is not a neutral recommendation. It is a product catalogue with arrows between the boxes.&lt;/p&gt;

&lt;p&gt;A consultancy reference architecture represents what worked at the clients that consultancy has served, filtered through the biases and preferences of the people who designed it. It may be excellent. It may also encode decisions that made sense in a context completely different from yours.&lt;/p&gt;

&lt;p&gt;A CNCF reference architecture represents the consensus view of a community with strong opinions about open source tooling. That community is smart and well-intentioned. It is also not operating your platform or accountable for your on-call rota.&lt;/p&gt;

&lt;p&gt;None of these are wrong. All of them require translation before they are useful to your specific organisation.&lt;/p&gt;

&lt;h2&gt;
  
  
  What to do instead
&lt;/h2&gt;

&lt;p&gt;Start with the problems your developers are actually experiencing, not with the architecture you want to build toward.&lt;/p&gt;

&lt;p&gt;If the problem is inconsistent deployment practices across teams, you need a CI/CD opinion and a way to enforce it. You may not need a service mesh, a service catalogue, and a full GitOps implementation on day one.&lt;/p&gt;

&lt;p&gt;If the problem is slow onboarding for new teams, you need a repeatable path from zero to first deployment. You may not need a sophisticated internal developer platform before you have validated what that path should look like.&lt;/p&gt;

&lt;p&gt;Use reference architectures as a map of the territory, not as a set of instructions. They tell you what exists and what is possible. They do not tell you what you need right now, in what order, or at what cost.&lt;/p&gt;

&lt;h2&gt;
  
  
  The question worth asking
&lt;/h2&gt;

&lt;p&gt;Before adopting any component from a reference architecture, ask one question: what specific problem does this solve for the engineers who will have to operate it?&lt;/p&gt;

&lt;p&gt;If you cannot answer that question concretely, the component is not ready to be adopted. It is being adopted because it is on the diagram.&lt;/p&gt;

&lt;p&gt;The best platform architectures I have worked with look nothing like the reference architectures they started from. They look like the specific, considered,incrementally &lt;br&gt;
validated answers to the specific problems that organisation &lt;br&gt;
faced.&lt;/p&gt;

&lt;p&gt;That is harder to put on a slide. It is also the only version that actually works.&lt;/p&gt;




&lt;p&gt;This is one of the themes I explore in &lt;br&gt;
&lt;a href="https://platformengineeringguide.com" rel="noopener noreferrer"&gt;The Comprehensive Guide to Platform Engineering&lt;/a&gt;, particularly around how platform teams make and sequence architectural decisions in practice rather than in theory. &lt;br&gt;
Free sample at &lt;a href="//platformengineeringguide.com/sample"&gt;Platform Engineering Guide Sample&lt;/a&gt; if you want to get a feel for the depth before committing.&lt;/p&gt;

</description>
      <category>platformengineering</category>
      <category>devops</category>
      <category>kubernetes</category>
      <category>architecture</category>
    </item>
    <item>
      <title>Why Most Internal Developer Platforms Fail (And What To Do About It)</title>
      <dc:creator>Jordan</dc:creator>
      <pubDate>Wed, 06 May 2026 11:08:29 +0000</pubDate>
      <link>https://forem.com/itzdaninja/why-most-internal-developer-platforms-fail-and-what-to-do-about-it-pd7</link>
      <guid>https://forem.com/itzdaninja/why-most-internal-developer-platforms-fail-and-what-to-do-about-it-pd7</guid>
      <description>&lt;p&gt;I've spent twenty years building and scaling platforms across financial services technology. In that time I've seen internal developer platforms succeed and I've seen them fail. The technical differences between the successes and the failures are smaller than you'd expect.&lt;/p&gt;

&lt;p&gt;The organisational differences are enormous.&lt;/p&gt;

&lt;h2&gt;
  
  
  The adoption problem nobody talks about
&lt;/h2&gt;

&lt;p&gt;Most IDP failures share a common characteristic: the platform team &lt;br&gt;
treated adoption as inevitable rather than earned.&lt;/p&gt;

&lt;p&gt;The assumption goes like this, if we build something genuinely better &lt;br&gt;
than what exists, developers will naturally migrate to it. This is &lt;br&gt;
rarely true. Developers are busy, sceptical of platform initiatives &lt;br&gt;
based on past experience, and rational about where they invest their &lt;br&gt;
time.&lt;/p&gt;

&lt;p&gt;The teams that get adoption right treat the platform as a product with a go-to-market problem. They identify a first team, make that team successful, and let word of mouth do the rest.&lt;/p&gt;

&lt;h2&gt;
  
  
  The metrics that actually matter
&lt;/h2&gt;

&lt;p&gt;The industry has converged on DORA metrics as the standard for &lt;br&gt;
measuring engineering performance. They're useful and worth tracking. &lt;br&gt;
But they measure outputs, not platform health.&lt;/p&gt;

&lt;p&gt;A platform can have strong DORA metrics and still be quietly failing.&lt;/p&gt;

&lt;p&gt;The metrics I've come to care about most:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Time to first deployment for a new team.&lt;/strong&gt; Not a team that's been &lt;br&gt;
on the platform for two years — a new team starting fresh. If this &lt;br&gt;
is measured in days rather than hours, the platform has an onboarding &lt;br&gt;
problem that deployment frequency won't reveal.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Unplanned dependency rate.&lt;/strong&gt; How often do developers go outside the &lt;br&gt;
platform to get something done? Every workaround is a product signal.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Platform team toil ratio.&lt;/strong&gt; What percentage of time is reactive &lt;br&gt;
versus proactive? If this isn't improving quarter on quarter, the &lt;br&gt;
platform is treading water.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Developer NPS.&lt;/strong&gt; Uncomfortable to measure. Impossible to argue with.&lt;/p&gt;

&lt;h2&gt;
  
  
  The documentation trap
&lt;/h2&gt;

&lt;p&gt;Platform teams that rely on documentation to drive adoption have &lt;br&gt;
already lost.&lt;/p&gt;

&lt;p&gt;If developers need to read three Confluence pages to understand how &lt;br&gt;
to deploy a service on your platform, the platform has a usability &lt;br&gt;
problem. The documentation is papering over the gap between what the &lt;br&gt;
platform is and what it should be.&lt;/p&gt;

&lt;p&gt;When I hear a platform team say "we need better documentation," I now &lt;br&gt;
ask a different question: what specifically are developers confused &lt;br&gt;
about, and why does the platform not make that thing obvious?&lt;/p&gt;

&lt;p&gt;The answer to that question is a product improvement. Not a new &lt;br&gt;
Confluence page.&lt;/p&gt;

&lt;h2&gt;
  
  
  Where this comes from
&lt;/h2&gt;

&lt;p&gt;These are some of the themes I explore in depth in &lt;br&gt;
&lt;a href="https://platformengineeringguide.com" rel="noopener noreferrer"&gt;The Comprehensive Guide to Platform Engineering&lt;/a&gt; a 550-page practitioner reference I've just published covering the full platform engineering lifecycle, from Kubernetes and GitOps through to IDPs, AI-native infrastructure, and the organisational change required to make any of it stick.&lt;/p&gt;

&lt;p&gt;Happy to discuss any of this in the comments, I'm particularly interested in what others are seeing around IDP adoption in practice.&lt;/p&gt;

</description>
      <category>platformengineering</category>
      <category>devops</category>
      <category>kubernetes</category>
      <category>sre</category>
    </item>
  </channel>
</rss>
