The Agile and DevOps Band-Aids

I am sure I don’t have to describe Agile software development to you. Almost every enterprise is applying Agile development methodology to a growing number of their software development efforts. There is no arguing that the appropriate application of the Agile development approach greatly enhances enterprise ability to foster change and innovation.

I have always had mixed emotions about the application of Agile development methodology to software development. I was delighted to see customers and developers working as one, but I lamented the treating of the symptoms vs. solving the problem that instigated the need to apply Agile development methodology in the first place. Now, given the onset of DevOps, yet another Band-Aid, I can no longer hold my tongue.

I don’t expect everyone will be familiar with DevOps. It is moving beyond its infancy into its toddler stage as I write this post. It is a growing movement that bridges the gap between software development groups and IT operations groups much in the same manner Agile software development can sometimes bridge the gap between customers and software developers. In a summary, DevOps is an emerging set of principles, methods and practices for communication, collaboration and integration between software development groups and IT operations groups. It is a response to the acknowledgement of the interdependence and criticality of both the software development and IT operations disciplines in meeting the increasing need for enterprises to drive rapid innovation. In a nutshell, DevOps gets software development and IT operations to work together so they don’t bring the introduction of new software to a crawl – thus losing the momentum of the Agile software development work. Damon Edwards wrote an post that provides a great description of DevOps

As with the application of Agile development methodology to software development, DevOps addresses the enterprise culture-based problem of function-centric work. For those of you unfamiliar with the idea of function-centric vs. process-centric work, let me make reference to the late great Dr. Michael Hammer. I had the privilege to meet, learn from, and work with Dr. Hammer when I was the IT Governance and Process Officer at a previous company. I viewed Dr. Hammer as the godfather of process and process management. I believe Dr. Hammer as much as anyone understood the crucial need for enterprises to master this critical discipline.  The following is his comparison of function-centric vs. process-centric organizations:

“Function-centric organizations are staffed by task workers with narrow perspectives and virtually total ignorance of the larger context in which they are working; in parochial organizational identification and affiliation, through which allegiance is given not to customer or company but to function and unit; and in incongruent measurement and reward systems that reinforce limited concerns and perspectives.”

“The focus in a process is not on individual units of work, which by themselves accomplish nothing for a customer, but rather on an entire group of activities that, when effectively brought together, create a result that customer’s value.”

The pervasiveness of function-centric constructs is the chief reason enterprises need to apply Agile development methodology to software development and DevOps to the introduction of that software to the production environment. Few enterprises are process-centric which means few organizations understand and manage work end-to-end. They cobble together disparate groups who toil on their chunk of the work and toss it over the fence to the next group. Agile development methodology and now DevOps addresses this problem by placing Band-Aids on the symptoms. The Agile Band-Aid is intended to fix the problem between customers and developers and now the DevOps Band-Aid is intended to fix the problem between developers and operations.

If you have not placed these Band-Aids on your function-centric enterprise wounds yet, you can expect to very soon. The onset of cloud computing and the screams for IT to drive rapid business innovation will make Agile software development and DevOps essential to your success. In the meantime, I will continue to evangelize the IT governance and process discipline necessary to solve the overarching enterprise problem of disparate disconnected function-centric groups.

Steve Romero, IT Governance Evangelist

Article source: CA ITGovernance Blog

Leave a Reply

Skip to toolbar