Comments
jcl wrote: Hi,thank you for this tutorial I'm interested on the first way to intregate Spring and EJB3. I have tried it in a example project buy it doesn't run. I'm searching since many time a solution,but nothing. I have posted on Spring forum,but no one seems can help me. I appreciate if you can help me.Thank you Antonio
Cloud Computing
Conference & Expo
November 2-4, 2009 NYC
Register Today and SAVE !..


2008 West
DIAMOND SPONSOR:
Data Direct
SOA, WOA and Cloud Computing: The New Frontier for Data Services
PLATINUM SPONSORS:
Red Hat
The Opening of Virtualization
GOLD SPONSORS:
Appsense
User Environment Management – The Third Layer of the Desktop
Cordys
Cloud Computing for Business Agility
EMC
CMIS: A Multi-Vendor Proposal for a Service-Based Content Management Interoperability Standard
Freedom OSS
Practical SOA” Max Yankelevich
Intel
Architecting an Enterprise Service Router (ESR) – A Cost-Effective Way to Scale SOA Across the Enterprise
Sensedia
Return on Assests: Bringing Visibility to your SOA Strategy
Symantec
Managing Hybrid Endpoint Environments
VMWare
Game-Changing Technology for Enterprise Clouds and Applications
Click For 2008 West
Event Webcasts

2008 West
PLATINUM SPONSORS:
Appcelerator
Get ‘Rich’ Quick: Rapid Prototyping for RIA with ZERO Server Code
Keynote Systems
Designing for and Managing Performance in the New Frontier of Rich Internet Applications
GOLD SPONSORS:
ICEsoft
How Can AJAX Improve Homeland Security?
Isomorphic
Beyond Widgets: What a RIA Platform Should Offer
Oracle
REAs: Rich Enterprise Applications
Click For 2008 Event Webcasts
Everyone wants to lower their capital expenditures and increase operational efficiency - it's a sign of the times. The economy of the past 12 - 18 months has forced all organizations to do more with less and become more efficient. While everyone can identify with the request to do more with less, th...
SYS-CON.TV
Services-Oriented Architecture and Services-Oriented Development of Applications
A strategy for transition

Services-oriented development of applications (SODA) is an important development model for enabling organizations to reorient business processes in the transition to a service-oriented architecture (SOA). This article describes one such approach.

Services-Oriented Development of Applications (SODA)
Gartner refers to SOA and SODA as foundational elements of future computing. SODA is a new style of developing software, designed to work specifically within the SOA paradigm. SOA represents a collection of loosely coupled, coarse-grained, heterogeneous components that can be easily snapped together using Web services. The result is enhanced developer productivity, code reuse, and business agility. The SOA Blueprints (www.middlewareresearch.com/soa-blueprints/), an industry-derived set of best practices and associated reference implementation, is an excellent resource for those looking to move to an SOA.

SODA is centered on the creation and assembly of services and service contracts first, deferring the design and implementation of the objects and components that realize the services until after the coarse-grained service contracts have been ironed out. SODA developers focus more on the process flow within and between applications, and less on the code that creates the underlying system. For a brief and to the point description of SODA, see www.serviceoriented.org/soda.html.

Pain Points
The issues described below are certainly not all-encompassing, but are meant to exemplify the issues that often impact a development process (particularly when undertaken by larger enterprises with multiple development teams), and which might be alleviated by transitioning to a SODA-based development approach.

Dependencies / Bottlenecks
Bottlenecks related to the ordering of dependencies are usually the biggest issue. Developers are often waiting for a dependent item to be designed and/or implemented before they can continue with their tasking. One of the issues is the division of labor in a multi-team environment. A standard division of labor often employed in this environment consists of having different teams working on the same vertical slice of functionality in different tiers, causing these dependency-related bottlenecks to spring up.

Management and mitigation of dependency-related issues is crucial to ensuring that developers can continue to be productive throughout development iterations; however, it isn't possible to "manage" a dependency issue away if many of the pieces are being developed in parallel (which is often the case with a fixed deadline).

Creation of the data model for each of an organization's releases (iterations) oftentimes begins roughly in parallel with the development of the software that interacts with it and not much earlier, which is not ideal but not always possible to avoid. Similarly, the domain model for a release may not be completed prior to a development iteration that will be using it. Proper planning in building out the data and domain models first is critical to avoiding these issues but if the project is already well underway, it is what it is ("next time, we'll do it right"). These issues result in a bottleneck for the business services, object/relational persistence mapping, and enterprise application integration (EAI)/business-to-business (B2B) developers, who require both data and domain models to be completed before much of their work can commence. The dependency problems can quickly cascade.

Division of Labor
Development teams are often divided horizontally by tier (especially those that are geographically dispersed). One team may be working on the presentation tier and the other on the business tier. This division often exists out of necessity due to the fact that off-site teams may not have access to the back-end systems with which the business tier needs to interact. Development of the presentation-tier functionality does not require access to these systems (at least during the design and initial implementation phases of the iteration). This division of labor has its problems, though, in that the development of discrete pieces of functionality (use cases) is being performed by separate (again, often geographically separated) teams. These teams often communicate through interfaces to business services and the data transfer objects (DTOs) (http://java.sun.com/blueprints/corej2eepatterns/ Patterns/TransferObject.html) exposed through them - a standard Java 2 Enterprise Edition (J2EE) best practice. The DTO structure and content often changes during a development iteration, as both the presentation and business services developers dig deeper into their designs and subsequent implementations. In addition, the structure/content of the DTOs is (mostly) driven by the structure of the domain model, and as it evolves, so do they. These issues could be lessened somewhat if the same team were working on an end-to-end slice of functionality (one team would be in control of the structure/content of the domain model, DTOs, business service interfaces, and the associated presentation). The key roadblock to going down a road with this approach is the capability to consistently simulate interfaces with the back-end systems, so that an off-site team can be given a full vertical slice. When teams are collocated, such back-end systems often have usage restrictions, especially when the back-end system is connected to and/or owned by another project, department, or business.

How Can a SODA Approach Help?
All resources are considered to be as services with SODA (from UI components on the front end to interaction with an external business partner on the back end). The primary development activity for the vast majority of developers here is the orchestration of those services. A small number of J2EE and integration gurus are responsible for the development of the implementation and/or extension of services in the case where the chosen SODA tools do not provide them off-the-shelf.

About Steve Buzzard
Steve Buzzard is currently working as a J2EE principal architect with Anexinet Corporation (www.anexinet.com), a leading systems integration firm headquartered in Philadelphia, with offices in New York and Washington D.C. Steve has over 19 years of experience in professional software development and has been working almost exclusively with the WebLogic Technology Stack since late 1998.

In order to post a comment you need to be registered and logged in.

Register | Sign-in

Reader Feedback: Page 1 of 1

SOA World Latest Stories
OpenAir, Inc., a NetSuite Inc. company and a provider of cloud computing professional services automation (PSA) and services resource planning (SRP) software announced that BearingPoint, a provider of management and technology consulting, has gone live with OpenAir to streamline servic...
“Our continued innovation in imaging software allows us to change the healthcare information distribution paradigm by the intuitive inclusion of images and radiology reports. We are thrilled to work with InSite One, a long-time partner, to bring this innovative solution to the market,”...
With their CRM and ERP data systems integrated, Tecan AG's staff and management will benefit from a real-time view of their corporate and customer information. The iBOLT business integration suite integrates and orchestrates the data between diverse business processes and applications....
Until today, Monitis was providing monitoring only for Amazon’s EC2 and S3 services. With the release of its Universal Cloud Monitoring Framework, Monitis can now sync to other Cloud computing providers very quickly - from Rackspace, GoGrid, Softlayer, and more. Monitis’ Universal Clou...
Solaris 10 10/09 provides new features, fixes and hardware support in an easy-to-install manner, preserving full compatibility with over 11,000 third-party products and customer applications, including Oracle database and application software. With over two decades of Sun/Oracle collab...
Optibase announced a new release of its MGW FlashStreamer encoding and streaming platform, introducing the innovative feature of capturing VGA and composite analog feeds and streaming them live as a single split-screen video. The “all-in-one” compact MGW FlashStreamer offers real-time ...
Subscribe to the World's Most Powerful Newsletters
Subscribe to Our Rss Feeds & Get Your SYS-CON News Live!
Click to Add our RSS Feeds to the Service of Your Choice:
Google Reader or Homepage Add to My Yahoo! Subscribe with Bloglines Subscribe in NewsGator Online
myFeedster Add to My AOL Subscribe in Rojo Add 'Hugg' to Newsburst from CNET News.com Kinja Digest View Additional SYS-CON Feeds
Publish Your Article! Please send it to editorial(at)sys-con.com!

Advertise on this site! Contact advertising(at)sys-con.com! 201 802-3021


SYS-CON Featured Whitepapers
ADS BY GOOGLE