Monday, March 29, 2010

Technical debt was first defined by Ward Cunningham as:

    "Shipping first time code is like going into debt. A little debt speeds development so long as it is paid back promptly with a rewrite... The danger occurs when the debt is not repaid. Every minute spent on not-quite-right code counts as interest on that debt. Entire engineering organizations can be brought to a stand-still under the debt load of an unconsolidated implementation, object-oriented or otherwise." - Wikipedia
I think Ward had it right, like that's a big surprise. Technical debt is like taking a loan out from a loan shark. You borrow at high rates and hopefully for a very short time. If you don't pay it back quickly you will end up paying a lot more over time. Making small payments on the debt will help but until you get it down to a very small sum, or zero, you have the issue of compunding interest.

What this means for solution development is that every time you take that short cut in the name of saving time, make a design decision that is "not the way it should be done", or not keeping vital documentation up-to-date you are incurring technical debt. All of these choices make the system more fragile, less maintainable, and more costly to run. This debt burdens a system until it is repaid. In some cases the debt becomes so high that the application is declared bankrupt and it is liquidated, that is it is replaced.

It does not take a lot of technical debt to start the bankruptcy process. When code becomes too fragile, the design too complicated, or too little documentation for the decision to be made to replace a solution rather than fixing it. A small amount of technical debt on even a single piece of code can lead a developer to not want to alter it because they don't understand it or are afraid of what the changes might do. This leads to "work arounds" such as creating new code for the specific condition the developer needs to deal with. This is typically implemented with some type of "if...then" block of code. Now we have two pieces of code that do practically the same thing. This makes the system even less maintainable and increases the technical debt.

The best way to deal with technical debt is recognize that it exists, track it, fix it, and then figure out how to fix the process so it doesn't happen again. This is a typical Six Sigma approach to quality issues. If a team tracks the decisions that lead to technical debt you not only track that it is out there but also give them the tools they will need to analyze how to prevent it in the future.

Make sure that you point out to management and your customers that you made some decisions during implementation that sere sub-optimal. Make them aware that not repaying the debt will lead to even higher balances int he future and a fragile system. This has to be expressed in business terms such as business lost productivity, unplanned outages, and increased support costs to name a few. If you can't convince them of the urgency of repaying the debt keep the list of technical debt around. Sooner or later they will come back to you and talk about a problem that you can directly relate back to the technical debt that you have on your list. this is an excellent opportunity to politely bring up the topic of technical debt again. Sometimes we don't succeed the first time we talk to them about technical debt but sooner or later you will get through!

Monday, February 8, 2010

Incremental vs. Iterative Development

I have been in several discussions lately about iterative versus incremental development and there has been a lot of confusion about what each means. I wanted to give my two cents on what I think the differences between the two are.

Incremental development to me is the process of building a whole piece of the solution to its completion and then moving on to the next piece. An analogy that I have used is the building of a house. Using an incremental approach you would build out all of the first floor, including the electrical, plumbing, dry wall, carpeting, etc. before starting anything on the second floor. This way you know that the first floor is complete and ready for the occupants to move in. In software development this would mean completing a subsystem, or a portion of the application, before you start the other subsystems or portions of the application.

Iterative development to me means building a business flow, with the minimum of functionality even, from start to end before adding more features, nice to haves, etc. Using the house analogy you would construct all the framing for a house before you added electrical, plumbing, etc. This way you are sure that all of the framing is solid and the rooms are laid out correctly before you start on the next feature/service.

Incremental and iterative development can co-exist in software development. You could complete one business process with minimal functionality quickly and then start on other business processes. Then you would start working on filling out the functionality of a business process iteratively. This would be incremental and iterative at the same time.

I prefer iterative development because I believe that showing business partners a minimally functioning solution before building out all the functionality gives them the opportunity to change the implementation before it is too costly to make the change. It also means that the business can make a decision that a feature may not be worth the development effort and launch without it.

Tuesday, January 19, 2010

Cloud Computing Buzz

There is a lot of buzz about Cloud computing lately that I think is misleading. Like all new IT silver bullets the advertising machines from vendors have been whipped up to a feverish pitch. They are selling all types of IT snake oil silver solutions and telling CIOs that if they don't have applications in the Cloud soon then they are behind the times and will be replaced soon.

First let me define what I mean by Cloud computing. I define Cloud computing as an externally hosted platform for running applications. This definition has also been known as Platform-as-a-Service or PaaS. Examples include Amazon's EC2 and Google's App Engine. There are many more out there but Amazon and Google are two well known providers. Others have defined Cloud computing as anything that doesn't run in your data center. This would include things like Google Docs, GMail, and the like. I think this is a stretch of the definition of Cloud computing since these are pre-defined applications that have a single purpose. Cloud computing is more general purpose than this definition.

I believe that Cloud computing has a place in the future of some companies. Companies that do not have the cash or people to put a data center together can get huge benefits from cloud computing. The ability to make infrastructure available quickly and inexpensively, initially at least, is exciting. There are several scenarios that companies can use this kind of infrastructure including proof of concept work, development environment, or even self contained applications.

I have an issue with the assumption that Cloud computing is a cure all for all IT problems. The Cloud does not solve the issues of integrating data from legacy systems, which now maybe defined as anything not running in the Cloud, development issues that arise from programming for a new environment, and even requirements issues. These problems will exist no matter where the solution is hosted. There are new issues that exist with hosting an application in the Cloud. Different national privacy laws, getting data out of the Cloud, and service availability are just a few issues that come off the top of my head. These all have far reaching affects on the suitability of Cloud computing for a company.

So if you are looking for a fast and efficient way to get infrastructure up and running then definitively look at cloud computing. But go in with your open. Have experienced IT people ask the hard questions about how the service works and how it will fit into your environment. Look at the cost of not only the infrastructure but the cost of developing and integrating the Cloud environment into your application portfolio.

Just my thoughts.

Tony