Understanding and Managing Technical Debt: Lessons from Azure DevOps | Martin Hinshelwood
👋 Hi, I’m Martin Hinshelwood from
NKD Agility
, and in this video, I break down the concept of technical debt, how it affects your team’s ability to deliver value, and why paying it back is essential. Using real-world examples, including insights from the Azure DevOps team, I’ll show you how managing technical debt can transform your product development process and unlock long-term productivity gains.
📌 Chapters:
- 00:00 – Introduction: What is Technical Debt?
- 02:30 – Known vs. Unknown Technical Debt
- 05:15 – Examples of Technical Debt in Action
- 08:45 – The Cost of Unpaid Technical Debt
- 12:00 – Lessons from Azure DevOps: Paying Back Technical Debt
- 16:30 – How Shorter Feedback Loops Drive Long-Term Value
- 20:00 – Strategies for Managing and Prioritizing Technical Debt
🎯 Who This Video is For:
- Product teams struggling with legacy systems and inefficiencies
- Developers and engineers looking to understand the impact of technical debt
- Engineering leaders focused on balancing feature delivery and system sustainability
- Organizations aiming to improve productivity and deliver more value
📖 What You’ll Learn:
- The definition of technical debt and how it accumulates (known and unknown)
- Real-world examples of technical debt from Azure DevOps and beyond
- Why technical debt isn’t just a cost—it’s a barrier to delivering value
- How paying back technical debt shortens feedback loops and increases productivity
- Practical strategies for managing technical debt effectively
💡 Key Takeaways:
- Technical debt is future work caused by prioritizing speed over long-term solutions.
- Known and unknown technical debt must be addressed to ensure product sustainability.
- Paying back technical debt doesn’t just improve quality; it enables teams to deliver more features faster.
- Shortening feedback loops through disciplined management of technical debt unlocks exponential value.
At
NKD Agility
, we help teams identify, manage, and pay back technical debt to create slick, sustainable systems that maximize value delivery. Ready to turn your technical debt into an opportunity for growth? Visit us today and let’s start building better software together.
#technicaldebt #softwaredevelopment #softwareengineering #agile #productdevelopment #productmanagement #projectmanagement #agileproductdevelopment #agileprojectmanagement #agileproductmanagement #productowner #projectmanager #scrummaster #productmanager #developer
Watch on Youtube
Technical debt is a huge problem for organisations. I want to quickly define technical debt. Technical debt is future cost that you incur when you or your team prioritise quick short-term solutions over more robust long-term approaches. Right, so anytime you make a choice to do something fast but wrong because you need it fast, you’re knowingly introducing technical debt. You can also unknowingly introduce technical debt, i.e., we made some architectural choices. They were good choices at the time, but now they’re no longer good choices. Technical debt can appear over time.
I’m thinking of a transactions system, and we supported X number of transactions per second, and our platform of choice was reasonably priced and was able to support well beyond what we thought we were going to transact. But now we’re transacting a lot more than that, and we’re reaching the limits of the system that we chose. A great example of that is the Azure DevOps team when they originally envisaged work item tracking fields. A work item was a row in a database, and fields were a column. Those of you who are software engineers have already figured out what the problem would be with that in that you can only have 1024 columns in a SQL database.
So they not quickly, but they did hit limitations on the number of columns that you could have for custom fields because who would have more than a thousand fields on a work item? But yeah, people do. They do exist, and people do that, and it was totally within the system. So they thought, “We’ll never have a thousand fields,” or somebody made that decision, just like the two-digit date decision back in the day. So they had a lot of work to go back and refactor, not just refactor the system but write the capabilities to refactor the data on upgrade for their customers into a format where each field was a row in a database rather than in a column.
So then you have unlimited capability for fields and data, and those types of decisions, either knowingly made decisions that result in something that’s not quite the way it needs to be or unknown ones, are where most technical debt comes from. There are other issues that people call technical debt which aren’t necessarily technical debt, but most people lump it all together and say technical debt. I think I often do as well, and that’s I’ve written bad code and shipped it. That’s not technical debt; that’s incompetence.
Right, so within the context of a competent team, there’s known technical debt and unknown technical debt. But there’s another thing that we call technical debt, which is just shipping bad code, making poor choices, knowing that they’re poor choices, and not doing anything about it. Right? Shipping bad code. Stop shipping bad code would be the way you pay that one back. But for technical debt, you need to pay it back. You need to prioritise paying back that technical debt. Think of it more as an unhedged fund rather than a debt like a credit card.
Most debt is secured against something, secured against an asset. If you stop paying your mortgage, then the bank comes and repossesses your house and gets their money back, right? And maybe you get some leftovers because you paid some of your mortgage. But who’s ensuring your product quality? Who’s ensuring your product against your technical debt? There’s no insurance; it’s uninsured from that perspective. Nobody can magically come along and pay back all the debt. It’s not insured at all, or sell something and pay back. We claim an asset, so it’s something you’re going to have to deal with, and you can’t let it get out of control.
And there’s a lot of unknown technical debt. I mean, that’s like, I mean, I use the Azure DevOps team a lot as an example, but they’d been a waterfall team for many years, shipping once every two years. And then they moved to a more continuous delivery three-week model, and they found that they made lots of poor decisions, right? That weren’t necessarily poor decisions within the context of two years, but they couldn’t really see the impact of the technical debt, the choices that they’d made, deliberate and undeliberate, right, on their ability to deliver product and their ability to deliver value.
But I have a graph of, I think it’s 2010 through to 2018 for that product team, so eight years of development, and they effectively go by moving to continuous delivery, moving to three-week sprints, moving to that faster cycle from a two-yearly cycle and running into issues with that. And every issue they’re running into, paying it back, right? Paying back the reason that they made those choices, which were perhaps valid reasons at the time, but you still need to pay it back. It doesn’t matter whether it was a valid reason or not.
And paying it back and doing the work, they actually went from 25 features to production each year in 2010 to something like 360 features to production in 2018. So by focusing on paying back their technical debt, enabling their engineers to close the feedback loops, then shorten the feedback loops, three ways of DevOps, right? Closing the feedback loops first, then shortening them. And that act of shortening the feedback loops can massively increase the amount of value that you can deliver long term.
And that’s the value of paying back technical debt, of managing technical debt well, is that you can go from removing those limitations to maximising the value that you deliver in your product with the same number of people. That was the Azure DevOps team literally went from 25 features to production each year in 2010, worked very hard to pay back technical debt, and were able to, even in the first year of focusing on paying back technical debt to get their new way of working up and running, they went from 25 features to production to 68 features to production within that one year.
And they weren’t even focused on delivering more features; they were focused on, “Let’s deal with our crap,” and “Let’s figure out how we deal with those problems.” And they still delivered more features. That’s the benefit of paying back technical debt. That’s the benefit of having a slick, easy system to add features to your product, and that’s what everybody needs. Don’t manage technical debt; pay it back.