Andrej Koelewijn

  • Home
  • About
  • Departments
    • cloud
    • java
    • mobile
    • open standards
    • oracle
    • oss
    • other
    • soa
    • software development
    • tablet
    • Uncategorized
    • web
  • Subscribe via RSS

SOA Governance: implicit or explicit

December 15th, 2009  |  Published in soa, software development  |  1 Comment

Today, during a SOA workshop we had a discussion about governance. Most people see the need for Governance when applying SOA. Without governance your beautiful flexible architecture will soon evolve into SOA spaghetti. Hard to modify, the opposite of business agility.

One goal of SOA governance is that it should verify that Services are reusable: Shared services over specific-purpose implementations.

Governance is usually associated with an enterprise architect role: a boss in charge of architecture. Someone who will police all architectural decision.

This approach to SOA governance is what i would call explicit governance. You explicitly appoint someone to do it. There are other ways of achieving the same goal. You can often design your systems and infrastructure in such a way that it’s only possible to do the right thing. You could call this implicit governance.

An example outside the field of IT: a restaurant has a goal to serve as many customers as possible per table everynight. To achieve this you could ask all the waiters to make sure the customers order fast, and pay fast. In this case the waiters are the police that have to implement to governance. Another way of achieving the same goal would be by having hard uncomfortable chairs, play loud music, and have loud colors in the decoration of the restaurant. In this situation nobody would have to do active governance: customers would just leave soon by themselves.

When doing SOA, you can also implement implicit governance: structure your infrastructure, methodology and organisation in such a way that it becomes really hard to do the wrong thing.

Some examples:

  • I often get the question if it’s ok for different services to share one database. Technically that isn’t a problem. As long as you have clearly separated services, only used by their interfaces. However, when you use just one database, you make it really easy to do the wrong thing. Developers can easily query a table part of another service. This will happen. Maybe because of deadlines, maybe because the business wants you to create a quick win. If every service has it’s own database, it will become harder for developers to cut corners.
  • If you have feature teams it’s easier for development teams to implement feature specific operations in a service. They just have their own requirements to think about, and may not consider re-usability enough. You can limit this risk by having service based teams which need to service requirements from multiple other teams. When implementing SOA it makes sense to have service based teams for the generic services, and feature based teams for the higher level requirements. It will make it harder for teams to do the wrong thing.

SOA governance will always be a combination of explicit and implicit governance, but i think it’s important to think about ways to do implicit governance.

More on this topic can be found in the design of everyday things: it discusses things like affordances and limitations. How do you design a product in such a way that it can only be used in the way intended? Many of the suggestions in this book can also be applied to the design of IT systems.

Share and Enjoy:
  • del.icio.us
  • Google Bookmarks
  • DZone
  • SphereIt
  • StumbleUpon
  • Technorati
  • LinkedIn
  • HackerNews
  • PDF
  • Digg
  • Facebook
  • FriendFeed
  • Posterous
  • Tumblr
  • Twitter
  • RSS
  • nordicsolutions

    SOA Governance: implicit or explicit http://bit.ly/54a75I


    This comment was originally posted on Twitter

  • brhubart

    Andrej Koelewijn: SOA Governance: implicit or explicit http://ff.im/-d4obC


    This comment was originally posted on Twitter

  • andrkoel

    blog post: soa governance – implicit or explicit? http://bit.ly/8uqwol


    This comment was originally posted on Twitter

blog comments powered by Disqus

Tags

bi bpel camel cep css dsl esb esper google governance grails groovy gtalk html5 innovation internet ipad ivy java javascript jaxrs jersey jigsaw jquery linkeddata linux maven middleware mule noiv openoffice openweb oracle osgi oss plsql rdbms rest soa sql sun tablet web 2.0 xmpp yql

Archives

  • March 2010
  • February 2010
  • January 2010
  • December 2009
  • November 2009
  • October 2009
  • August 2009
  • July 2009
  • June 2009
  • May 2009
  • April 2009
  • March 2009
  • February 2009
  • January 2009
  • December 2008
  • November 2008
  • October 2008

Meta

  • Log in
  • Entries RSS
  • Comments RSS
  • WordPress.org

Recent Posts

  • Getting started with Nexus maven repository manager
  • JEE CDI tip: Target Unreachable, identifier resolved to null
  • Absent Code attribute in method that is not native or abstract
  • Prezi presentation software needs to add visual
  • So you think it’s the iPad that’s missing features?

Categories

  • cloud
  • java
  • mobile
  • open standards
  • oracle
  • oss
  • other
  • soa
  • software development
  • tablet
  • Uncategorized
  • web

Recent Comments

  • andrej on So you think it’s the iPad that’s missing features?
  • Dave on So you think it’s the iPad that’s missing features?
  • andrej on So you think it’s the iPad that’s missing features?
  • Fernando on So you think it’s the iPad that’s missing features?
  • andrej on So you think it’s the iPad that’s missing features?

RSS Friendfeed

  • Google’s Chief Economist: “Newspapers Have Never Made Much Money From News” March 10, 2010
    andrej koelewijn Google’s Chief Economist: “Newspapers Have Never Made Much Money From News” - http://techcrunch.com/2010... 16 hours ago from Google Reader - Comment - Like […]
    FriendFeed
  • Researching differences between Mule and Oracle OSB, any chance of reusing mule code in osb... March 10, 2010
    andrej koelewijn Researching differences between Mule and Oracle OSB, any chance of reusing mule code in osb... 23 hours ago from Twitter - Comment - Like […]
    FriendFeed
  • RT @monkchips: DHS: Smartphones to Sniff Out Suspicious Substances http://bit.ly/cq2JRD March 10, 2010
    andrej koelewijn RT @monkchips: DHS: Smartphones to Sniff Out Suspicious Substances http://www.dhs.gov/files... 24 hours ago from Twitter - Comment - Like […]
    FriendFeed
  • Amerikanen rangschikken Rotterdams MVRDV in top 50 March 9, 2010
    andrej koelewijn Amerikanen rangschikken Rotterdams MVRDV in top 50 - http://www.idealize.nl/2010... Tuesday from Google Reader - Comment - Like […]
    FriendFeed
  • Getting started with Nexus maven repository manager March 9, 2010
    andrej koelewijn Getting started with Nexus maven repository manager - http://www.andrejkoelewijn.com/wp... Tuesday from Google Reader - Comment - Like […]
    FriendFeed
  • @eelzinga Did you add the remote repository to the correct reposutory group in nexus? http://bit.ly/a2gTmZ March 9, 2010
    andrej koelewijn @eelzinga Did you add the remote repository to the correct reposutory group in nexus? http://www.andrejkoelewijn.com/wp... Tuesday from Twitter - Comment - Like […]
    FriendFeed
  • Getting started with Nexus maven repository manager March 9, 2010
    andrej koelewijn Getting started with Nexus maven repository manager - http://www.andrejkoelewijn.com/wp... Tuesday from Andrej Koelewijn - Comment - Like […]
    FriendFeed
  • Re: 7 Reasons For Apple To Acquire Adobe March 7, 2010
    andrej koelewijn Re: 7 Reasons For Apple To Acquire Adobe - http://thenextweb.com/apple... Saturday from Disqus - Comment - Like "Seems to me you left out the most important reason: ipad will be about media convergence: combining books with magazines, newspapers, tv and internet. Currently adobe seems to have the best tools to create these new types of […]
    FriendFeed
  • Do we need a new tech literacy? (Behind the “big data” services like Twitter, Facebook use) March 6, 2010
    andrej koelewijn Do we need a new tech literacy? (Behind the “big data” services like Twitter, Facebook use) - http://scobleizer.com/2010... Saturday from Google Reader - Comment - Like […]
    FriendFeed
  • Pivot: Business intelligence meets the internet as a database http://bit.ly/bFc6wp March 6, 2010
    andrej koelewijn Pivot: Business intelligence meets the internet as a database http://infosthetics.com/archive... Saturday from Twitter - Comment - Like […]
    FriendFeed


©2010 Andrej Koelewijn
Powered by WordPress using the Gridline Lite theme by Graph Paper Press.