InfoQ

News

Agile Strategies for Enterprise Architects

Posted by Floyd Marinescu on Apr 12, 2007 03:55 PM

Community
Agile
Topics
Leadership ,
Governance
Scott Ambler has written some advice for Enterprise Architects looking to tailor their enterprise architecture processes to support agile software development teams, in an article appearing in a Cutter Consortium EA report  summarized here.

In the article, Scott makes the case to the enterprise architect that agile software development teams work differently, and an EA needs to know how to engage with such teams "in a manner that reflects agile approaches to software development." Scott first identifies what agile teams need from the EA:
  • Hands-on involvement. Not just designing but actually coding too.  
  • Straightforward guidance on common standards and guidelines. Agile teams believe in coding and similar standards, but EA's "must be prepared to maintain and collaboratively support it."
  • Overview diagrams. "I personally find that a high-level enterprise domain model, a UML deployment diagram providing a high-level overview of the technical infrastructure, a free-form “architectural stack” diagram, and a high-level enterprise business process model are very useful for business applications."
  • Reference architectures. Reference implementations to illustrate desired standards and implementation approaches. 
  • Mentoring. "architectural concepts, modeling, design, and in other systems within your organization."
Scott then goes on to show what Agile teams don't need from them:
  • Detailed documentation.  Hands-on access is much better. 
  • Authoritative governance. "Agile teams work best with a collaborative approach to governance, not a command and control one."
  • Reviews. "Reviews are “process smells”; if holding a review makes sense, then it’s an indication that you’ve very likely made a serious mistake earlier in the development process. "
Scott concludes:
Enterprise architects have it really tough these days because they have to support traditional, agile, and even hybrid development teams. The implication is that enterprise architects need to be flexible and to be prepared to adapt to the situation at hand. Development teams should not be required to adapt, at least not significantly, to meet the needs of enterprise architects. In my experience, the surest way to failure is to have the enterprise architecture tail wag the development dog.
The Cutter Consortium report is free as a downloadable PDF with registration required.
  • This article is part of a featured topic series on Governance

No comments

Watch Thread Reply

Educational Content

Bindings, Platforms, and Innovation

This presentation focuses on the Internet and separating myth from fact, history from the future, and the mundane from the imaginative. Bob Frankston presents a vision of what could and should be.

Orchestrating Long Running Activities with JBoss / JBPM

This article explores the use of JBoss and jBPM to implement design solutions that effectively address the issue of orchestrating long running activities.

Neo4j - The Benefits of Graph Databases

This presentation covers the use of graph databases as an optimal solution for data that is difficult to fit in static tables, rapidly evolving data or data that has a lot of optional attributes.

Realistic about Risk: Software development with Real Options

This session introduces Real Options and shows how it can help in running your project. Real Options is a decision-making process that can be used to manage risk.

Communication Flexibility Using Bindings

This article discusses the use of bindings on services and references (including the instance of non-configured bindings) as the means to implement SCA communications in a Web and SOA environment.

Writing DSLs in Groovy

After a short introduction to DSLs, Scott Davis plays with the keyboard showing how to approach the creation of a DSL by typing working snippets of Groovy code that get executed.

Scaling Agile with C/ALM (Collaborative Application Lifecycle Management)

IBM Rational and InfoQ present, Scaling Agile with C/ALM, an eBook showing organizations how to become “finely tuned software delivery machines” by enabling team integration and scaling.

Concurrent Programming with Microsoft F#

Amanda Laucher presents a real life enterprise application written in F#. She shows actual code snippets, explaining design decisions and suggesting how to use some of the F# constructs.