service oriented architecture alberto polzonetti

61
Service Oriented Architecture Alberto Polzonetti

Post on 19-Dec-2015

215 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Service Oriented Architecture Alberto Polzonetti

Service Oriented Architecture

Alberto Polzonetti

Page 2: Service Oriented Architecture Alberto Polzonetti

Service-Oriented Architecture: Concepts, Technology, and Design

By Thomas Erl

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

.

Publisher: Prentice Hall PTR

Pub Date: August 04, 2005

ISBN: 0-13-185858-0

Pages: 792

Service-Oriented Architecture: Concepts, Technology, and Design

By Thomas Erl.

Publisher: Prentice Hall PTR

Pub Date: August 04, 2005

ISBN: 0-13-185858-0 Pages: 792

Page 3: Service Oriented Architecture Alberto Polzonetti

Additional information

• The XML & Web Services Integration Framework (XWIF)– Some of the contents in this book originated from research I performed

for SOA Systems Inc. (formerly XMLTC Consulting Inc.), as part of the XML & Web Services Integration Framework (XWIF) project. For more information, visit www.soasystems.com or www.xwif.com.

• www.serviceoriented.ws– Updates, source code, and various other supporting resources can be

found at www.serviceoriented.ws. I am interested in your feedback. Any experiences you'd like to share or suggestions you may have as to how I can continue to improve this book would be much appreciated.

• Contact the Author– www.thomaserl.com/technology.

Page 4: Service Oriented Architecture Alberto Polzonetti

Case Studies • Due to the distinctive nature of modern-day

service-oriented architectures, using case studies is an effective way of conveying the topics covered by this book. Though purely fictional, the examples derived from these case studies raise common issues and problems faced by typical IT departments

• RailCo Ltd.

• Transit Line Systems Inc.

Page 5: Service Oriented Architecture Alberto Polzonetti

Part I – INTRODUCING Part I – INTRODUCING SOASOA

Part I – INTRODUCING Part I – INTRODUCING SOASOA

Page 6: Service Oriented Architecture Alberto Polzonetti

Foundamental SOA

1. the term "service-oriented" has existed for some time, it has been used in different contexts and for different purposes

2. Approach1. the logic required to solve a large problem can be better

constructed, carried out, and managed if it is decomposed into a collection of smaller, related pieces.

2. Each of these pieces addresses a concern or a specific part of the problem.

3. This approach transcends technology and automation solutions. It is an established and generic theory that can be used to address a variety of problems.

Page 7: Service Oriented Architecture Alberto Polzonetti

A service oriented analogy

Page 8: Service Oriented Architecture Alberto Polzonetti

Service Oriented and Composition

The definition of software services aligns with the business services that a bank offers to ensure smooth business operations and to help realize strategic goals such as providing ATM and Web access to banking services in addition to providing them in the branch office.

Page 9: Service Oriented Architecture Alberto Polzonetti

Architecture

• When coupled with "architecture," service-orientation takes on a technical connotation.

• "Service-oriented architecture" is a term that represents a model in which automation logic is decomposed into smaller, distinct units of logic.

• Collectively, these units comprise a larger piece of business automation logic. Individually, these units can be distributed.

Page 10: Service Oriented Architecture Alberto Polzonetti

Services oriented• Business CommunityBusiness Community

– impose dependencies inhibit the potential of individual businesses. – empowering businesses to self-govern their individual services allow

them to evolve and grow relatively independent from each other.– Independence within our business outlets, and adhesion to certain

baseline conventions– standardization key aspects of each business for the benefit of the

consumers without significantly imposing on the individual business's ability to exercise self-governance.

• Service-oriented architecture (SOA)Service-oriented architecture (SOA)– encourages individual units of logic to exist autonomously yet not

isolated from each other. – Units of logic are still required to conform to a set of principles that

allow them to evolve independently, while still maintaining a sufficient amount of commonality and standardization.

– Within SOA, these units of logic are known as services.

Page 11: Service Oriented Architecture Alberto Polzonetti

How services encapsulate logic

• each service can encapsulate – a task performed by

an individual step– a sub-process

comprised of a set of steps.

• A service can even encapsulate the entire process logic.

Page 12: Service Oriented Architecture Alberto Polzonetti

How services relate (I) • The relationship between services is based on

an understanding that for services to interact, they must be aware of each other. service service descriptionsdescriptions.

• A service description establishes– the name of the service– the data expected and returned by the service.

Page 13: Service Oriented Architecture Alberto Polzonetti

How services relate (II)

• The manner in which services use service descriptions results in a relationship classified as loosely coupledloosely coupled.

• A communications framework capable of preserving their loosely coupled relationship is therefore required. One such framework is messagingmessaging.

Page 14: Service Oriented Architecture Alberto Polzonetti

How services communicate

• After a service sends a message, it loses control of what happens to the message thereafter.

• That is why we require messages to exist as "independent units of communication."

• Messages, like services, should be autonomous

Page 15: Service Oriented Architecture Alberto Polzonetti

How services are designed (I)

DISTINCT DESIGN APPROACH

Page 16: Service Oriented Architecture Alberto Polzonetti

How services are designed :key aspects

• Loose coupling Services maintain a relationship that and only

requires that they retain an awareness of each other.

• Service contract Services adhere to a communications agreement

• Autonomy Services have control over the logic they encapsulate.

• Abstraction Services hide logic from the outside world.

• Reusability Logic is divided into services with the intention of promoting reuse.

• Composability Collections of services can be coordinated and assembled to form composite services.

• Discoverability Services are designed to be outwardly descriptive so that they can be found and assessed via available discovery mechanisms.

Page 17: Service Oriented Architecture Alberto Polzonetti

How services are built• the term "service-oriented" and various abstract

SOA models existed before the arrival of Web services.

• However, no one technology advancement has been so suitable and successful in manifesting SOA than Web services.

• All major vendor platforms currently support the creation of service-oriented solutions, and most do so with the understanding that the SOA support provided is based on the use of Web services.

Page 18: Service Oriented Architecture Alberto Polzonetti

Primitive SOA

represents a baseline technology architecture that is supported by current major vendor platforms

Page 19: Service Oriented Architecture Alberto Polzonetti

Contemporaney SOA

• Major software vendors are continually conceiving new Web services specifications and building increasingly powerful XML and Web services support into current technology platforms.

• The result is an extended variation of service-oriented architecture we refer to as contemporary SOA.

Page 20: Service Oriented Architecture Alberto Polzonetti

Summary 1.1

• SOA and service-orientation are implementation

paradigms that can be realized with any suitable

technology platform.

• Primitive SOA model represents a mainstream

variation of SOA based solely on Web services and

common service-orientation principles.

• SOA and service-orientation are implementation

paradigms that can be realized with any suitable

technology platform.

• Primitive SOA model represents a mainstream

variation of SOA based solely on Web services and

common service-orientation principles.

Page 21: Service Oriented Architecture Alberto Polzonetti

Common Caratherstics

Page 22: Service Oriented Architecture Alberto Polzonetti

SOA is fundamentally autonomous

• individual services be as independent

• self-contained as possible with respect

to the control they maintain over their

underlying logic.

Page 23: Service Oriented Architecture Alberto Polzonetti

SOA increases quality of service

• Ability for tasks to be carried out in a secure manner,

protecting the contents of a message, as well as access to

individual services.

• Reliability so that message delivery or notification of failed

delivery can be guaranteed.

• Overhead imposed by SOAP message and XML content

processing does not inhibit the execution of a task.

Page 24: Service Oriented Architecture Alberto Polzonetti

SOA is based on open standards

• Standard open technologies are used within and

outside of solution boundaries.

Page 25: Service Oriented Architecture Alberto Polzonetti

SOA supports vendor diversity

Page 26: Service Oriented Architecture Alberto Polzonetti

SOA promotes discovery

Page 27: Service Oriented Architecture Alberto Polzonetti

SOA encourages intrinsic interoperability

Page 28: Service Oriented Architecture Alberto Polzonetti

SOA promotes federation

Page 29: Service Oriented Architecture Alberto Polzonetti

SOA promotes architectural composability

• Different solutions can be composed of different

extensions and can continue to interoperate as long as

they support the common extensions required.

Page 30: Service Oriented Architecture Alberto Polzonetti

SOA encourages intrinsic reusability

Page 31: Service Oriented Architecture Alberto Polzonetti

SOA emphasizes extensibility

• Extensible services can expand functionality with

minimal impact.

Page 32: Service Oriented Architecture Alberto Polzonetti

SOA supports a service-oriented business modeling paradigm

• Partitioning business logic into services that can then be

composed has significant implications as to how business

processes can be modeled

Page 33: Service Oriented Architecture Alberto Polzonetti

SOA implements layers of abstraction

• Application logic created with proprietary technology

can be abstracted through a dedicated service layer.

Page 34: Service Oriented Architecture Alberto Polzonetti

SOA promotes loose coupling throughout the enterprise

Page 35: Service Oriented Architecture Alberto Polzonetti

SOA promotes organizational agility

Page 36: Service Oriented Architecture Alberto Polzonetti

SOA general definition

• SOA is a form of technology architecture that adheres to the principles of service-orientation.

• When realized through the Web services technology platform, SOA establishes the potential to support and promote these principles throughout the business process and automation domains of an enterprise.

Page 37: Service Oriented Architecture Alberto Polzonetti

SOA Formal definition• Contemporary SOA represents an open, agile,

extensible, federated, composable architecture comprised of autonomous, QoS-capable, vendor diverse, interoperable, discoverable, and potentially reusable services, implemented as Web services.

• SOA can establish an abstraction of business logic and technology that may introduce changes to business process modeling and technical architecture, resulting in a loose coupling between these models.

• SOA is an evolution of past platforms, preserving successful characteristics of traditional architectures, and bringing with it distinct principles that foster service-orientation in support of a service-oriented enterprise.

Page 38: Service Oriented Architecture Alberto Polzonetti

Common misperceptions about SOA

Page 39: Service Oriented Architecture Alberto Polzonetti

• An application that uses Web services is service-oriented – you need to standardize how Web services are

positioned and designed, according to service-orientation principles.

• SOA is just a marketing term used to re-brand Web services – SOA is a legitimate and relatively established

technical term. It represents a distinct architecture based on a set of distinct principles.

• If you understand Web services you won't have a problem building SOA

• Once you go SOA, everything becomes interoperable

Page 40: Service Oriented Architecture Alberto Polzonetti

Common tangible benefits of SOA

• Improved integration (and intrinsic interoperability)

• Inherent reuse • Simplified architectures and solutions • Leveraging the legacy investment • Establishing standardized XML data

representation • Focused investment on communications

infrastructure • Organizational agility

Page 41: Service Oriented Architecture Alberto Polzonetti

Common pitfalls of adopting SOA

• Building service-oriented architectures like traditional distributed architectures

• Not standardizing SOA • Not creating a transition plan • Not starting with an XML foundation

architecture • Not understanding SOA performance

requirements • Not understanding Web services security

Page 42: Service Oriented Architecture Alberto Polzonetti

Summary 1.2

• We recognize contemporary SOA with a number of common

characteristics that build upon and extend the original qualities and

principles established by primitive SOA.

• Some of the more dangerous assumptions about SOA are that

service-oriented solutions are simple by nature, easy to build, and

automatically interoperable

• When assessing the return on investment for an SOA there are several

concrete benefits that can be taken into account.

• Many of the pitfalls relate to a limited understanding of what SOA is

and what is required to fully incorporate and standardize service-

orientation.

• A transition plan is the best weapon against the obstacles that tend to

face organizations when migrating toward SOA.

• We recognize contemporary SOA with a number of common

characteristics that build upon and extend the original qualities and

principles established by primitive SOA.

• Some of the more dangerous assumptions about SOA are that

service-oriented solutions are simple by nature, easy to build, and

automatically interoperable

• When assessing the return on investment for an SOA there are several

concrete benefits that can be taken into account.

• Many of the pitfalls relate to a limited understanding of what SOA is

and what is required to fully incorporate and standardize service-

orientation.

• A transition plan is the best weapon against the obstacles that tend to

face organizations when migrating toward SOA.

Page 43: Service Oriented Architecture Alberto Polzonetti

Part II - The evolution Part II - The evolution of SOAof SOA

Part II - The evolution Part II - The evolution of SOAof SOA

Page 44: Service Oriented Architecture Alberto Polzonetti

XML: brief history• Like HTML, the Extensible Markup Language (XML)Extensible Markup Language (XML) was

a W3C creation derived from the popular Standard Generalized Markup Language (SGML) that has existed since the late 60s.

• This widely used meta language allowed organizations to add intelligence to document data.

• The language itself was used as the basis for a series of additional specifications.

– XML Schema Definition Language (XSD) and XSL XML Schema Definition Language (XSD) and XSL Transformation Language (XSLT)Transformation Language (XSLT) were both authored using XML. (These specifications, in fact, have become key parts of the core XML technology set)

Page 45: Service Oriented Architecture Alberto Polzonetti

Web Services:a brief history (I)

• In 2000, the W3C received a submission for the Simple

Object Access Protocol (SOAP) specification.

– This specification was originally designed to unify (and in some

cases replace) proprietary RPC communication. The idea was

for parameter data transmitted between components to be

serialized into XML, transported, and then deserialized back into

its native format.

Page 46: Service Oriented Architecture Alberto Polzonetti

• This ultimately led to the idea of creating a pure, Web-

based, distributed technology (one that could leverage

the concept of a standardized communications

framework to bridge the enormous disparity that existed

between and within organizations).

• This concept was called Web services.

• The most important part of a Web service is its public

interface.

– It is a central piece of information that assigns the service an

identity and enables its invocation

Web Services:a brief history (II)

Page 47: Service Oriented Architecture Alberto Polzonetti

• One of the first initiatives in support of Web services was

the Web Service Description Language (WSDL).

– The W3C received the first submission of the WSDL language in

2001 and has since continued revising this specification.

• IBM and Microsoft were each working on a way to

programmatically describe how to connect to a Web

Service. After some discussion, protocol proposals from

Microsoft and IBM merged. In late 2000, a merged

specification, Web Services Description Language

(WSDL), was announced.

Web Services:a brief history (III)

Page 48: Service Oriented Architecture Alberto Polzonetti

• Completing the first generation of the Web services standards family was the UDDI specification. – Originally developed by UDDI.org, it was submitted to OASIS,

which continued its development in collaboration with UDDI.org.

• This specification allows for the creation of standardized service description registries both within and outside of organization boundaries.

• UDDI provides the potential for Web services to be registered in a central location, from where they can be discovered by service requestors.

• Unlike WSDL and SOAP, UDDI has not yet attained

industry-wide acceptance, and remains an optional extension to SOA.

Web Services:a brief history (IV)

Page 49: Service Oriented Architecture Alberto Polzonetti

Early incarnation of SOA: architecture modeled around three

basic components

Page 50: Service Oriented Architecture Alberto Polzonetti

Standard Organizations that contribute to SOA

• W3C– In the SOA arena, its role has been primarily as a standards

body responsible for specifications that provide core and generic functionality.

• OASIS – Its overall goal is to support the creation of standards targeted at

specific industries and to foster trade and commerce between eBusiness-enabled enterprises.

• WS-I – not produce technology standards. I– nstead, this organization provides profile documents that

establish a proven and tested collection of standards. Compliance to these profiles guarantees organizations that their environments support a level of industry-standard interoperability.

Page 51: Service Oriented Architecture Alberto Polzonetti

Comparision of Standards Organizations

Page 52: Service Oriented Architecture Alberto Polzonetti

Reading: compare SOA to past architectures

• SOA vs. client-server architecture • SOA vs. distributed Internet architecture • SOA vs. hybrid Web service architecture

Page 53: Service Oriented Architecture Alberto Polzonetti

The Service-Oriented Enterprise

Page 54: Service Oriented Architecture Alberto Polzonetti

Extensible Markup Language (XML)

• Standard data types and structures, independent of any programming language, development environment, or software system.

• Pervasive technology for defining business documents and exchanging business information, including standard vocabularies for many industries.

• Ubiquitous software for handling operations on XML, including parsers, queries, and transformations.

Page 55: Service Oriented Architecture Alberto Polzonetti

Web services

• Pervasive, open standards for distributed computing interface descriptions and document exchange via messages.

• Independence from the underlying execution technology and application platforms.

• Extensibility for enterprise qualities of service such as security, reliability, and transactions.

• Support for composite applications such as business process flows, multi-channel access, and rapid integration.

Page 56: Service Oriented Architecture Alberto Polzonetti

Service-oriented architecture (SOA)

• A strong architectural focus, including governance, processes, modeling, and tools.

• An ideal level of abstraction for aligning business needs and technical capabilities, and creating reusable, coarse-grain business functionality.

• A deployment infrastructure on which new applications can quickly and easily be built.

• A reusable library of services for common business and IT functions

Page 57: Service Oriented Architecture Alberto Polzonetti

Business process management (BPM)

• Explicitly describe business processes so that they are easier to understand, refine, and optimize.

• Make it easier to quickly modify business processes as business requirements change.

• Automate previously manual business processes and enforce business rules.

• Provide real-time information and analysis on business processes for decision makers.

Page 58: Service Oriented Architecture Alberto Polzonetti
Page 59: Service Oriented Architecture Alberto Polzonetti

Why Web Services ?

• The reason is that when exposing the capabilities of software components, we are essentially exposing software services.

• The goal is for these services to be widely available over the World-Wide Web (more strictly we really mean the Internet) — hence the term ‘Web

Page 60: Service Oriented Architecture Alberto Polzonetti

RailCo• RailCo Ltd. is an established

parts supplier for railways, specializing in air brakes and related installation tools.

• RailCo ships air brake parts internationally, but 90% of its sales are in North America.

• Though its primary line of business is product resale, RailCo also has a small group of specialized technicians that are hired out locally for installations and repairs.

Page 61: Service Oriented Architecture Alberto Polzonetti

TLS• Transit Line Systems Inc. (TLS) is

a prominent corporation in the private transit sector.

• It employs over 1,800 people and has offices in four cities.

• Though its primary line of business is providing private transit, it has a number of secondary business areas, including the following:

– A maintenance and repair branch that outsources TLS service technicians to public transit sectors.

– Parts manufacturing for other industries.

– A tourism branch that partners with airlines and hotels.