YOUR FEEDBACK
Ubuntu Here We Come! - Java Finally To Become 100% Open Source
Reader wrote: Since November 206, wow! that is a long process.
SOA World Conference
Virtualization Conference
$200 Savings Expire May 16, 2008... – Register Today!

SYS-CON.TV
TOP THREE LINKS YOU MUST CLICK ON


Building SOA with Tuscany SCA
A simple service-oriented infrastructure

Digg This!

Page 2 of 4   « previous page   next page »

This very simple mechanism of applying bindings to the services and references defined by a component is at the root of SCA's ability to separate business logic from deployment concerns. It works regardless of whether the component implementation is brand new or wraps some existing business logic.

It is also the mechanism by which SCA components communicate with services outside of SCA. Bindings can be defined such that existing applications can access SCA services or can be referenced by SCA components. This flexibility allows the SCA approach to be introduced incrementally within an organization.

SCA simplifies business logic development with dependency injection by providing an Inversion of Control (IoC) container. As you can see from the Java code snippet below, the component simply declares references and properties using Java annotations. The account service talks to account data service, stock quote service, and calculator service by making direct calls on the interfaces. The code here deals with business logic only and no traditional technology API calls are required. Tuscany handles how the services are located, who provides the services, and how messages are delivered based on information in the SCA configuration.

@Service(AccountService.class)
public class AccountServiceImpl implements AccountService {

   @Reference
   protected StockQuoteService stockQuoteService;

   ...

   @Property
   protected String currency;

   public double getAccountReport(String customerID) {

     // Get the stock price in USD
     double price = stockQuoteService.getQuote(stock.getSymbol());

     // Convert to the configured currency
     if (currency.equals("EURO")) {

         price = calculatorService.multiply(price, 0.70);
     }
     ...
   }
}

SCA also provides a mechanism to separate organizational infrastructure concerns from business logic through policy statements that enable agreed constraints to be applied at deployment time. This could range from dictating which communications should be encrypted to describing which level of monitoring and logging is required. For example, the helloworld-ws-service-secure sample [6] shows how to express the intention that clients accessing a service must be authenticated before doing so.

<component name="HelloWorldServiceComponent">
   <implementation.java class="helloworld.HelloWorldImpl" />
   <service name="HelloWorldService" requires="authentication">
     <interface.wsdl interface="http://helloworld#wsdl.interface(HelloWorld)" />
     <binding.ws uri="http://localhost:8085/HelloWorldService"/>
   </service>
</component>

Note that the <service> element carries a policy intent that interactions require "authentication." How authentication is actually implemented is then a matter of policy within the organization.

We have demonstrated how the flexibility of the SCA programming model helps address enterprise challenges. Another area to point out is the ability to use any implementation language and therefore leverage existing skills and investments. Tuscany SCA provides support for a selection of languages for building business logic, for example, XQuery, BPEL, script. The BigBank demo implements the various operations of the calculator using scripting languages. Tuscany SCA's implementation.script currently supports JavaScript, Groovy, Ruby, and Python. In the SCA configuration example below, implementation.script indicates that the business logic of the AccountServiceComponent is written in JavaScript.

<component name="AddServiceComponent">     <tuscany:implementation.script script="calculator/AddServiceImpl.js"/> </component>

Tuscany SCA also supports Spring and OSGi implementation types. New or existing Spring applications or OSGi bundles can be used to provide the implementation for SCA components. These components can be easily composed with other service components and deployed consistently in a distributed network of Tuscany SCA runtimes with the full range of communication methods made available to them.

Enabling Web 2.0
A typical Web 2.0 application will reference several services in the organization and integrate the provided data in the browser. Tuscany SCA enables such services using popular technologies such as JSONRPC, RSS, and Atom protocols.

Tuscany demonstrates how a Web 2.0 application, and the services it relies on, can be constructed using an Internet shopping example called "Store" [7]. There is a guide that walks through the steps required to build this sample [8].

From Figure 2 you can see a Catalog component providing a service to the Web 2.0 application over JSONRPC. The Catalog component provides information about the products the store has for sale and has been constructed without regard for how it might be accessed. Using Tuscany SCA the Catalog component's Java implementation is associated with the JSONRPC binding (binding.jsonrpc).

<component name="Catalog">
   <implementation.java class="services.CatalogImpl"/>
   <service name="Catalog">
     <t:binding.jsonrpc/>
   </service>
   ...
</component>



Page 2 of 4   « previous page   next page »

About Haleh Mahbod
Haleh Mahbod is a program director with IBM, managing the team contributing to the Apache Tuscany as well as SOA for PHP open source. She has extensive development experience with database technologies and integration servers.

About Raymond Feng
Raymond Feng is a senior software engineer with IBM. He is now working on the Service Component Architecture (SCA) runtime implementation in Apache Tuscany project as a committer. Raymond has been developing SOA for more than 4 years and he was a key developer and team lead for WebSphere Process Server products since 2002.

About Simon Laws
Simon Laws is a member of the IBM Open Source SOA project team working with the open source Apache and PHP communities to build Java, C++, and PHP implementations of the Service Component Architecture (SCA) and Service Data Object (SDO) specifications. Prior to this role he was working in the distributed computing space building service-oriented solutions for customers with a particular interest in grid computing and virtualization.

anonymous wrote: SCA sounds a lot like CORBA.. or is it just me seeing this?
read & respond »
anonymous wrote: SCA = CORBA CORBA = failure SCA = ??
read & respond »
WEBSPHERE LATEST STORIES . . .
IBM Unveils Insurance Operations of the Future Powered By SOA
IBM announced two new advances in the insurance industry - a solution for improving operational efficiency and a framework for process acceleration - that are designed to help insurance providers lower costs and increase customer satisfaction by handling core processes, such as claims
ParAccel Announces OEM Relationship with IBM
ParAccel announced it has entered into an original equipment manufacturer (OEM) agreement with IBM. Under the terms of the agreement, ParAccel will embed IBM InfoSphere Change Data Capture within the ParAccel Analytic Database, providing ParAccel customers with seamless and real-time u
Microsoft To Keynote 4th International Virtualization Conference & Expo
Mike Neil is general manager for virtualization strategy in the Windows Server Division at Microsoft. Mike is focused on the delivery of the Windows virtualization technology, including Windows Server 2008 Hyper-V, Microsoft Hyper-V Server and Virtual PC 2007. Mike also directs the tec
Micro Focus Upgrades SOA Express for IBM CICS
Micro Focus announced the availability of SOA Express 8.0. The new version adds support for direct deployment into IBM's Customer Information Control System (CICS), enabling users to accelerate the deployment of Web services by reusing their existing CICS TS mainframe infrastructure in
3rd International Virtualization Conference & Expo: Themes & Topics
From Application Virtualization to Xen, a round-up of the virtualization themes & topics being discussed in NYC June 23-24, 2008 by the world-class speaker faculty at the 3rd International Virtualization Conference & Expo being held by SYS-CON Events in The Roosevelt Hotel, in midtown
Red Hat Named "Platinum Sponsor" of Virtualization Conference & Expo
Red Hat is a trusted open source provider. Red Hat offers enterprise customers a long-term plan for building infrastructures on the quality and innovation of open source. Combining open source operating system platform, Red Hat Enterprise Linux, together with applications, management
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
BREAKING WEBSPHERE NEWS
Bryan Flanagan, Director of Training for Zig Ziglar, to Teach Sales Skills at American Marketing Association Mastering Sales Seminar, May 23, Irving, TX
Nationally renowned speaker, author and sales trainer, Bryan Flanagan, Director of Corporate T