<?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: Prasad Rane</title>
    <description>The latest articles on Forem by Prasad Rane (@prasad_rane_dev).</description>
    <link>https://forem.com/prasad_rane_dev</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%2F3428548%2Fbccbc728-3fdb-45cd-aaf8-750e7075a85b.jpg</url>
      <title>Forem: Prasad Rane</title>
      <link>https://forem.com/prasad_rane_dev</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/prasad_rane_dev"/>
    <language>en</language>
    <item>
      <title>Starting Enterprise-wide Kafka Governance</title>
      <dc:creator>Prasad Rane</dc:creator>
      <pubDate>Wed, 06 May 2026 17:35:52 +0000</pubDate>
      <link>https://forem.com/prasad_rane_dev/starting-enterprise-wide-kafka-governance-14e2</link>
      <guid>https://forem.com/prasad_rane_dev/starting-enterprise-wide-kafka-governance-14e2</guid>
      <description>&lt;p&gt;Technical leadership isn't always about having the right title; it’s about having the right influence. When you are operating without direct authority, setting standards across autonomous teams requires a shift from "enforcing mandates" to "solving shared pain."&lt;/p&gt;

&lt;h2&gt;
  
  
  The Mess: Visualizing the Chaos
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ftfbw8nxbumjc34vafo97.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ftfbw8nxbumjc34vafo97.png" alt="Visualizing the Chaos" width="649" height="354"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;It began on a Tuesday in a conference room, facing a whiteboard filled with chaotic arrows representing event flows. The AWS MSK dashboard displayed a patchwork of inconsistent topic names.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;loan-processing.loancreated
LoanService.Events.Created
mortgage.v2.loan.originated
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;These topics often performed the same functions but were impossible to correlate during system failures. Same intent. Same cluster. Completely different conventions.&lt;/p&gt;

&lt;p&gt;When something broke, tracing ownership or flow was guesswork.&lt;/p&gt;

&lt;p&gt;But naming inconsistencies were just the symptom.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;IAM policies ranged from overly permissive to painfully restrictive&lt;/li&gt;
&lt;li&gt;Schema evolution had no guardrails&lt;/li&gt;
&lt;li&gt;Ownership was unclear&lt;/li&gt;
&lt;li&gt;Every team used Kafka differently&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The real issue was simple:&lt;/p&gt;

&lt;p&gt;Everyone depended on Kafka. Nobody owned its governance.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;That’s how technical debt quietly compounds; until it becomes operational risk.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h2&gt;
  
  
  The Realization: Governance is a Missing System, Not a Missing Rule
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ftinoe0zk0sn3wfvn54yn.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ftinoe0zk0sn3wfvn54yn.png" alt="The Realization" width="270" height="421"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Sitting down, one thought became clear:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;We’re building technical debt faster than we can document it.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Without intervention, cross-service debugging would become unsustainable within a year. But there was a constraint:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;No central authority&lt;/li&gt;
&lt;li&gt;No mandate power&lt;/li&gt;
&lt;li&gt;Fully autonomous teams
This wasn’t a tooling problem. It was a coordination problem.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Meeting Invite: Start with Pain, Not Policy
&lt;/h2&gt;

&lt;p&gt;Instead of proposing a solution, I invited collaboration by framing it as a way to fix shared frustrations.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F45y3t4krbx3ro5ujt0ql.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F45y3t4krbx3ro5ujt0ql.png" alt="Meeting Invite" width="359" height="426"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;That framing mattered. No one wants another rulebook. But everyone wants their pain heard. &lt;br&gt;
Five engineers showed up:&lt;br&gt;
2 from platform engineering&lt;br&gt;
3 from application teams&lt;/p&gt;

&lt;p&gt;That was enough to start.&lt;/p&gt;

&lt;h2&gt;
  
  
  The Meeting: Shifting from Skepticism to Engagement
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F7htckrxe9ig5b2u4jhby.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F7htckrxe9ig5b2u4jhby.png" alt="Shifting from Skepticism to Engagement" width="639" height="422"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;In the meeting, I led with pain points rather than solutions, showing real examples of redundant and confusing topics on the MSK dashboard.&lt;br&gt;
Then someone said:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;“We got paged last week because a producer couldn’t write to a topic. Nobody knew how to fix it.”&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;That changed the room. We moved from:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;“Why are we here?”&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;to&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;“We need to fix this.”&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;That shift from abstract discussion to shared pain is where influence begins.&lt;/p&gt;

&lt;h2&gt;
  
  
  Drafting Standards: The Technical Blueprint
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fsz002l1w9n59vbe9ff1e.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fsz002l1w9n59vbe9ff1e.png" alt="Drafting Standards" width="577" height="417"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Over the next two weeks, I drafted the first version of a governance framework. It focused on three pillars:&lt;/p&gt;

&lt;h3&gt;
  
  
  1.Topic Naming Convention
&lt;/h3&gt;

&lt;p&gt;Convention: &lt;code&gt;{domain}.{service}.{event-type}.{version}&lt;/code&gt;&lt;br&gt;
Example: &lt;code&gt;loan.loanservice.loan-created.v1&lt;/code&gt;&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Goal: Make the topic names - discoverable, searchable, self-descriptive, and future-proof with versioning.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h3&gt;
  
  
  2. IAM Policies (Least Privilege)
&lt;/h3&gt;

&lt;p&gt;Creating mandatory least-privilege templates tied to service roles to eliminate wildcards.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Goal: Make the secure path the default path.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h3&gt;
  
  
  3. Schema Evolution (Avro + Compatibility)
&lt;/h3&gt;

&lt;p&gt;Enforced Avro with BACKWARD compatibility which is integrated with schema registry and gets checked before deployment.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Goal: Prevent breaking downstream consumers silently&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h2&gt;
  
  
  Automation: If It’s Not Enforced, It’s Optional
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fptsjr6p1g7agh1uyygvx.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fptsjr6p1g7agh1uyygvx.png" alt="Enforcing the rules" width="631" height="421"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Documentation alone doesn’t scale. So we embedded the standards into tooling.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Terraform Modules&lt;/strong&gt;: Topic provisioning templates now included regex validation for naming and pre-configured IAM defaults.&lt;br&gt;
&lt;strong&gt;CI/CD Linters&lt;/strong&gt;: We built a linter to flag violations in service configuration files before deployment. &lt;br&gt;
Example failure: &lt;code&gt;FAILED: topic name 'test_topic' does not match pattern&lt;/code&gt;&lt;br&gt;
Example success: &lt;code&gt;PASS: topic 'loan.loanservice.loan-created.v1'&lt;/code&gt;&lt;br&gt;
&lt;strong&gt;Gate&lt;/strong&gt;: Automation turned guidance into a "gate," ensuring that the right way was also the only way to deploy.&lt;br&gt;
That’s when governance becomes real:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Not a suggestion. A system constraint.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h2&gt;
  
  
  The Tipping Point: Adoption Without Intervention
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ft8ui608c6g8ay5gbgqxu.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Ft8ui608c6g8ay5gbgqxu.png" alt="Adoption" width="645" height="425"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Three months later, something subtle happened. I was reviewing a PR from a team I’d never worked with.&lt;/p&gt;

&lt;p&gt;Everything passed:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Naming ✔&lt;/li&gt;
&lt;li&gt;IAM ✔&lt;/li&gt;
&lt;li&gt;Schema ✔&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;No feedback needed. That’s when I knew:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;The system didn’t need me anymore.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;And that’s the goal of good governance.&lt;/p&gt;

&lt;h2&gt;
  
  
  Key Takeaway
&lt;/h2&gt;

&lt;p&gt;This experience reshaped how I think about technical leadership:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Standards don’t succeed because they’re correct.&lt;br&gt;
They succeed because people believe in them.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;h3&gt;
  
  
  What Actually Worked
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;Start with pain, not policy&lt;/li&gt;
&lt;li&gt;Involve stakeholders early&lt;/li&gt;
&lt;li&gt;Facilitate, don’t dictate&lt;/li&gt;
&lt;li&gt;Bake standards into tooling&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Final Thought
&lt;/h2&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fr2lf6hw306it01avbp3q.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fr2lf6hw306it01avbp3q.png" alt="Result" width="638" height="423"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;If you're working on platform or architecture problems in a multi-team environment, remember:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;You don’t need authority to create alignment. &lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;You need:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;clarity&lt;/li&gt;
&lt;li&gt;empathy&lt;/li&gt;
&lt;li&gt;and systems that reinforce good decisions&lt;/li&gt;
&lt;/ul&gt;

&lt;blockquote&gt;
&lt;p&gt;Standards stick when they make people’s lives better — not when they add gates.&lt;/p&gt;
&lt;/blockquote&gt;

</description>
      <category>kafka</category>
      <category>microservices</category>
      <category>softwareengineering</category>
      <category>leadership</category>
    </item>
    <item>
      <title>The Feynman Algorithm: A Developer’s Guide to "Thinking Very Hard"</title>
      <dc:creator>Prasad Rane</dc:creator>
      <pubDate>Mon, 27 Apr 2026 16:06:50 +0000</pubDate>
      <link>https://forem.com/prasad_rane_dev/the-feynman-algorithm-a-developers-guide-to-thinking-very-hard-384h</link>
      <guid>https://forem.com/prasad_rane_dev/the-feynman-algorithm-a-developers-guide-to-thinking-very-hard-384h</guid>
      <description>&lt;p&gt;If you search for Richard Feynman’s methods, you’ll likely stumble upon the famous Feynman Technique, a brilliant framework for learning new concepts by explaining them to a child.&lt;/p&gt;

&lt;p&gt;But there’s another, lesser-known Feynman method. It was jokingly coined by his colleague, physicist Murray Gell-Mann, who said that Feynman’s process for solving problems looked like this:&lt;/p&gt;

&lt;blockquote&gt;
&lt;ol&gt;
&lt;li&gt;Write down the problem.&lt;/li&gt;
&lt;li&gt;Think very hard.&lt;/li&gt;
&lt;li&gt;Write down the solution.&lt;/li&gt;
&lt;/ol&gt;
&lt;/blockquote&gt;

&lt;p&gt;At first glance, this sounds like a meme. "Draw the rest of the owl," right? But if we look closer at this "Feynman Algorithm," it actually perfectly outlines the lifecycle of debugging and writing software.&lt;br&gt;
Let’s break down how this tongue-in-cheek algorithm can actually help you become a better developer.&lt;/p&gt;




&lt;h3&gt;
  
  
  Step 1: Write down the problem ✍️
&lt;/h3&gt;

&lt;p&gt;Albert Einstein supposedly said, &lt;em&gt;"If I had an hour to solve a problem, I'd spend 55 minutes thinking about the problem and 5 minutes thinking about solutions.&lt;/em&gt;"&lt;/p&gt;

&lt;p&gt;In programming, we often skip this. We see an error log and immediately start changing variables and refreshing the browser. But "writing down the problem" forces you to define exactly what is going wrong.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Bad Problem Definition:&lt;/strong&gt;&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"The login page is broken."&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;&lt;strong&gt;Good Problem Definition:&lt;/strong&gt;&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;"When a returning user tries to log in with Google OAuth, the API returns a 500 server error, but only on mobile Safari."&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;When you write the problem down clearly, the scope narrows. Half the time, simply defining the problem accurately reveals the solution.&lt;/p&gt;




&lt;h3&gt;
  
  
  Step 2: "Think very hard" 🧠
&lt;/h3&gt;

&lt;p&gt;This is the punchline of the joke. To outsiders, Feynman just stared at a chalkboard and magically found the answer. But "thinking very hard" doesn't mean having a massive IQ; it means engaging in &lt;strong&gt;structured, focused analysis&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;How do developers "think very hard"?&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;We Rubber Duck&lt;/strong&gt;: We explain the code line-by-line to an inanimate object (or a patient coworker).&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;We Isolate&lt;/strong&gt;: We comment out chunks of code to see if the bug still happens. We narrow down the variables.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;We Step Away&lt;/strong&gt;: Sometimes, "thinking very hard" means taking a shower or going for a walk. Your brain's "diffuse mode" keeps working on the problem in the background.&lt;/p&gt;

&lt;p&gt;"Thinking very hard" means resisting the urge to copy-paste the first Stack Overflow answer you see without understanding why it works.&lt;/p&gt;




&lt;h3&gt;
  
  
  Step 3: Write down the solution 💡
&lt;/h3&gt;

&lt;p&gt;You figured it out! You fixed the bug! Time to push to production and go home, right? Not quite.&lt;/p&gt;

&lt;p&gt;In the context of coding, "writing down the solution" means three things:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Writing clean code&lt;/strong&gt;: Making sure your solution isn't just a hacky workaround, but a readable, maintainable piece of logic.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Writing tests&lt;/strong&gt;: Proving that your solution actually works and ensuring it won't break in the future.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Writing documentation&lt;/strong&gt;: Leaving comments explaining why you did what you did.&lt;/p&gt;

&lt;p&gt;Your future self (and your team) will thank you when they read a comment like:&lt;/p&gt;

&lt;p&gt;&lt;code&gt;// Using a Set here instead of an Array because checking for duplicates was causing a massive performance bottleneck.&lt;/code&gt;&lt;/p&gt;




&lt;h3&gt;
  
  
  Final Thoughts
&lt;/h3&gt;

&lt;p&gt;The Feynman Algorithm might have started as a joke among Nobel Prize-winning physicists, but it’s remarkably practical for software engineers.&lt;/p&gt;

&lt;p&gt;Next time you are stuck on a nasty bug, don't just start mashing the keyboard. Stop. Write the problem down. Take a walk to think very hard. And when you solve it, document it for the next developer.&lt;/p&gt;

&lt;p&gt;Let me know in the comments how you practice "thinking very hard" when you are stuck on a tricky coding problem!&lt;/p&gt;

</description>
      <category>programming</category>
      <category>productivity</category>
      <category>beginners</category>
      <category>developer</category>
    </item>
  </channel>
</rss>
