InfoQ

News

InfoQ Article: Top 8 SOA Adoption Pitfalls

Posted by Miko Matsumura on Jul 20, 2006 12:01 PM

Community
SOA
Topics
Stories & Case Studies
Tags
Blueprints

Thomas Erl is the world's top-selling SOA author. He has written two books on SOA.  In this InfoQ article, Thomas explains the pitfalls others have fallen victim to inorder to help you chart a safer route down your own SOA roadmap. To this end he has collected the eight most common SOA adoption pitfalls he has noticed last year and explains which ones are still releavant this year.  Check out Thomas Erl's  Top 8 SOA Adoption Pitfalls.


In brief, the pitfalls are:
#8 Not Keeping in Touch with the SOA Marketplace
#7 Not Planning for Web Services Security
#6 Not Planning for Governance
#5 Not Understanding SOA Performance Requirements
#4 Not Starting with an XML Foundation Architecture
#3 Not Creating a Transition Plan
#2 Not Standardizing SOA
#1 Building SOA Like Traditional Distributed Architecture

How many of these pits have you falled into?

9 comments

Reply

Why XML? Why vendor? by James Richardson Posted Jul 21, 2006 11:22 AM
Re: Why XML? Why vendor? by Stuart Charlton Posted Jul 24, 2006 9:06 PM
Re: Why XML? Why vendor? by Stuart Charlton Posted Jul 24, 2006 9:13 PM
Re: Why XML? Why vendor? by John Harby Posted Jul 25, 2006 6:41 AM
Re: Why XML? Why vendor? by James Richardson Posted Jul 25, 2006 10:06 AM
Re: Why XML? Why vendor? by Jeff Thomas Posted Jul 25, 2006 3:35 PM
Suprised by the lack of fret over #2 Standardize SOA by Jim Murphy Posted Jul 26, 2006 7:28 AM
Re: Suprised by the lack of fret over #2 Standardize SOA by Eric Roch Posted Aug 1, 2006 3:44 PM
Re: Why XML? Why vendor? by Jim Murphy Posted Jul 26, 2006 7:24 AM
  1. Back to top

    Why XML? Why vendor?

    Jul 21, 2006 11:22 AM by James Richardson

    Despite being very popular and free, there are more performant and less verbose extensible data serialization formats. (e.g XER/PER)

    Secondly - one needs to realise that the main purpose for the existence of vendors is to vend. Therefore they have a vested interest in making all the WS-* layers require their tools. However its totally possible to avoid a lot of complexity by simply not using vendor products, and doing "the simplest thing that could possibly work".

    Jetty A Servlet XStream can get you off the ground very quickly - not a vendor tool in sight...

  2. Back to top

    Re: Why XML? Why vendor?

    Jul 24, 2006 9:06 PM by Stuart Charlton

    This is a very unfair characterization of vendors, and I would also say a somewhat idealistic stance.

    Firstly, the XML verbosity argument is often irrelevant; the web is built on a very verbose markup language called HTML and seems to be doing just fine. There are many use cases that require a more compact form, but they tend to be the exception.

    Secondly, Why XML? Let me pose an alternative question: Why is broken English the most widely communicable form of language, even though there are other more efficient languages like Esperanto?

    There are plenty of contexts where an alternative to XML is applicable, such as JSON with AJAX. But one must recognize the serious economic tradeoff in making such an architectural decision. One shouldn't focus overly heavily on technological mechanisms when building an SOA; XML is not mandatory, but a whole lot more people will understand you than if you speak first century Aramaic.

    Third, vending supposes there is "need" out there. One can argue whether that need is manufactured or is real. I would say it's likely a combination of both. Clearly, there are many use cases that WS-* covers that you can't point to in nearly another other standard, save rarely implemented CORBA services.

    Some large customers happen to have tremendous clout with large vendors

  3. Back to top

    Re: Why XML? Why vendor?

    Jul 24, 2006 9:13 PM by Stuart Charlton

    Looks like I got truncated there.

    Some large customers happen to have tremendous clout with large vendors. Large vendors have clout with standards bodies. Thus a reflexive process occurs, where communities of practice think alike and guide a standard down a particular path, which guides client perceptions, which guides vendors, etc.

    Many clients want WS-*, even though URIs, HTTP and SSL would likely suffice for most use cases. They have their reasons - some legitimate, some not. But if they're willing to pay millions for an enterprise deal, it's hard for a vendor to at least be a "fast follower" of such standards, regardless of their actual success or value.

  4. Back to top

    Re: Why XML? Why vendor?

    Jul 25, 2006 6:41 AM by John Harby

    I agree with Stuart completly. The anti-XML argument probably doesn't hold much water except in the extreme cases. It has to be emphasized that SOA is really about distribution and how many distributed scenarios represent that sort of traffic where the message size will make a difference? Also, if you do have use cases with that sort of traffic can't patterns be employed to drop down or channel them around the ESBs, etc.?

  5. Back to top

    Re: Why XML? Why vendor?

    Jul 25, 2006 10:06 AM by James Richardson

    I am merely challenging the assumption that either xml or vendor is absolutely required to have a SOA. It depends on what floats your boat.

    While disagreeing, you simultaneously agree, by saying vendors are sometimes brought in "regardless of their success or value", and that xml is good "except in the extreme cases" - of which I can think of a lot.

    The need for these things should be decided upon by a rational decision process, rather than assumption. (as is the case with everything)

  6. Back to top

    Re: Why XML? Why vendor?

    Jul 25, 2006 3:35 PM by Jeff Thomas

    I agree that one can certainly have a valid SOA without XML. But it seems that many performance-oriented critics of SOAP/WS-* SOA are treating the proposition as if it were an application programming model and not an integration model.

  7. Back to top

    Re: Why XML? Why vendor?

    Jul 26, 2006 7:24 AM by Jim Murphy

    Let me add my 2 cents in support of vendors, since I represent one.

    The point of spending the last decade pushing for the widest possible standards ever has been to get as many people as possible "on the bus" (not the ESB, the metaphorical "lets all go in the same direction bus"). The point of that is to offload common, crosscutting concerns that app developers have been baking into systems themselves. The "openness" of wire protocol, metadata and policy supports a high degree of automation and composability of various vendor products.

    Obviously you need to be the judge of what automation and proucts you should compose but its a tremendous opportunity we have to raise the level of software development 1 notch.

  8. I often wonder what this means to people. Establishing a SOA council to adopt patterns and practices sounds like standardization. So does defining a common XML data model for an enterprise or even industry. But those efforts seem to be really hard to do. Try to get a bank to agree on the data model of a contact/person/organization/trading partner/entity etc. Then if and when you have standardized how do you evolve?

    Does standardizing at a low level stifle future innovation? Once you have that in place is there ever a chance of moving ahead?

  9. XML can be a challenge but it?s difficult if not impossible to avoid using. Even if you don?t want to use XML your business partners will likely force you to. There are also great tools for authoring and storing (repository) XML and there are XML accelerators if performance becomes a problem.

    See this post for more tips on XML and SOA.

    blogs.ittoolbox.com/eai/business/archives/xml-s...

Exclusive Content

Fast Bytecodes for Funny Languages

Cliff Click discusses how to optimize generated bytecode for running on the JVM. Click analyzes and reports on several JVM languages and shows several places where they could increase performance.

Scott Ambler On Agile’s Present and Future

Scott Ambler, Practice Lead for Agile Development at IBM, speaks on the current status of the Agile community and practices having a look at the perspective of the Agile’s future.

Manager's Introduction to Test-Driven Development

Dave Nicolette and Karl Scotland try to introduce non-technical managers to one of the most popular Agile development techniques: Test-Driven Development (TDD).

Structured Event Streaming with Smooks

Smooks is best known for its transformation capabilities, but in this article Tom Fennelly describes how you can also use it for structured event streaming.

How to Work With Business Leaders to Manage Architectural Change

Successful architectures evolve over time to meet changing business requirements. Luke Hohmann presents how to collaborate with key members of your business to manage architectural changes.

Colors and the UI

In this article, Dr. Tobias Komischke explains how colors used in a GUI can influence our interaction with a computer and offers advice on using the appropriate colors for the interface.

Building your next service with the Atom Publishing Protocol

In his presentation, recorded at QCon San Francisco, MuleSource architect Dan Diephouse explores ways to use the Atom Publishing Protocol (AtomPub) when building services in a RESTful way.

Column Level Security in SharePoint

Grzegorz Gogolowicz and Matthew Dressel demonstrate how to extend Windows SharePoint Services 3.0 to support column level permissions.