February 10, 2008   Sign In |  About ebizQ |  Contact Us |  Join ebizQ Gold Club
David Linthicum
Dave Linthicum's Podcast Channel
Industry expert Dave Linthicum's musings on the integration industry, delivered once a week.

« 9 Things You Must Understand about Orchestration | Main | Keynote in San Francisco »

June 16, 2006
Turning Old APIs into New Services

As I’m exposed to more service-oriented development projects and SOAs I’m finding that good service design, as well as how existing services are exposed, is core to success. Also, there is not much difference between good traditional application design techniques and good service design techniques, many of the same notions apply. The most important thing is to build your SOA to meet your own business requirements. That’s the test of a good design.

Of course, most services are not built as new services, they are exposed out of existing systems. So, how you expose services in that manner is a bit more involved, especially when considering granularity. In essence you’re not designing a service, but you are designing the abstractions of that service.

When exposing existing services you typically can’t decide as to what will exist as a raw service in the systems your exposing, however you can abstract them in such a way that you create a set of well designed and defined services, even if the raw (originating) services are not.

For instance, we may look to expose a very course grained service, an poorly designed API perhaps, found in an existing legacy application.. Say the pattern is: Manage Employees, which is a complete set of functions bound to a single API call or service that manages all employee data, including add, edit, validate, update, delete, etc.

We are able to expose this API as a service, but we may want to go a few steps further including breaking this service out into many independent services by building abstract services (plural) above the raw service. It’s the role of this process to make the larger more course grain service appear as fine grained or as course grained as needed for a good usable design.

Posted by davel at 09:20 AM in | Digg This | Add to del.icio.us

Comments Post a comment




Remember Me?



We ask that you type your code (displayed below) in the text box.This code is an image that cannot be read by a machine. It prevents automated programs from submitting comments.


Code:



Most Recent ebizQ Blog Entries
ADVERTISEMENT
RSS Subscription

Categories
Blog Roll
This Work
Accountability:The opinions expressed in this blog are solely representative of the blog's author, and not of ebizQ

Subscribe to our Newsletters
ebizQ Weekly Gold Club Update
Live Webinar Updates
Updates from ebizQ Partners
ebizQ SOA Update
ebizQ BPM Update
ebizQ Security Update
ebizQ BI Update
ebizQ Open Source Software Update
Virtual Show Newsletter
Your E-mail Address:
BAM: The Killer App for CEP
Date: Feb 12, 2008
Time: 12:00 PM ET
(17:00 GMT)

I WANT TO ATTEND
Event Processing Market Pulse
Date: Feb 14, 2008
Time: 12:00 PM ET
(17:00 GMT)

I WANT TO ATTEND
Archived Webinars | Upcoming Webinars

Marketing Solutions | Feedback | About ebizQ | Unsubscribe | Privacy Policy | Site Map