Tải bản đầy đủ (.pdf) (14 trang)

SADpdf

Bạn đang xem bản rút gọn của tài liệu. Xem và tải ngay bản đầy đủ của tài liệu tại đây (118.5 KB, 14 trang )

<span class='text_page_counter'>(1)</span><div class='page_container' data-page=1>

<b>TU-Wien </b>



<b>Service Oriented Architecture </b>


<b>Software Architecture Document </b>



</div>
<span class='text_page_counter'>(2)</span><div class='page_container' data-page=2>

TU-Wien, 2005 Page 2 of 14


<b>Revision History </b>



<b>Date </b> <b>Version </b> <b>Description </b> <b>Author </b>


26/March/2005 1.0 Architectural description of service


</div>
<span class='text_page_counter'>(3)</span><div class='page_container' data-page=3>

TU-Wien, 2005 Page 3 of 14


<b>Table of Contents </b>



1. Introduction 4


1.1 Purpose 4


1.2 Scope 4


1.3 Definitions, Acronyms and Abbreviations 4


1.4 References 4


1.5 Overview 4


2. Architectural Representation 5



3. Architectural Goals and Constraints 5


3.1 Google Web Service Constraints 5


3.2 Amazon Web Service Constraints 6


3.3 Standards and used technologies 6


4. Use-Case View 7


4.1 Use-Case Realizations 7


4.1.1 Google Search Use case 7


4.1.2 Amazon Search Use case 7


4.1.3 Combined Search Use case 7


5. Logical View 8


5.1 Overview 8


5.2 Architecturally Significant Design Packages 9


5.2.1 Amazon Package 9


5.2.2 Google Package 10


5.2.3 Server Package 10



6. Deployment View 11


7. Implementation View 12


8. Size and Performance 13


9. Quality 13


9.1 Performance 14


9.2 Security 14


9.3 Portability 14


</div>
<span class='text_page_counter'>(4)</span><div class='page_container' data-page=4>

TU-Wien, 2005 Page 4 of 14


<b>Software Architecture Document </b>



<b>1. </b>

<b>Introduction </b>



This document provides a high level overview of the technical architecture for the Service oriented
architecture exercise. It outlines the technologies that have been used for a simple service oriented
application which uses available services of Google and Amazon to present a new combined service. In
facilitating interoperability through standards, combined service will help its users to enhance their queries
by querying both Google and Amazon simultaneously.


The document provides a high-level description of the goals of the architecture, the use cases support by
the system and architectural styles and components that have been selected to best achieve the use cases.
This framework then allows for the development of the design criteria and documents that define the
technical and domain standards in detail.



<b>1.1 </b> <b>Purpose </b>


This document provides a comprehensive architectural overview of the system, using a number of different
architectural views to depict different aspects of the system. It is intended to capture and convey the
significant architectural decisions which have been made on the system.


With the ability to integrate data and applications through Web services, many opportunities will arise for
greater collaboration and more elaborated services on internet. This document will provide an overview of
technologies used and software architecture.


<b>1.2 </b> <b>Scope </b>


This software architecture document applies to the exercise of “Software Architectures” course presented in
winter semester 2004 by Distributes Systems Group, Vienna University of Technology.


<b>1.3 </b> <b>Definitions, Acronyms and Abbreviations </b>


<b>SOAP</b> Simple Object Access Protocol,


<b>UDDI</b> Universal Description, Discovery and Integration,


<b>URL</b> Uniform Resource Locator,


<b>WSDL</b> Web Services Definition Language,


<b>Eclipse </b> Open extensible IDE,


<b>1.4 </b> <b>References </b>



Service Oriented Architecture specifications,



<b>1.5 </b> <b>Overview </b>


</div>
<span class='text_page_counter'>(5)</span><div class='page_container' data-page=5>

TU-Wien, 2005 Page 5 of 14

<b>2. </b>

<b>Architectural Representation </b>



Search Service is an application based on Web Services technologies and standards. The application
receives a keyword from user and then this keyword will be sent to Google and Amazon web services. The
result of these two queries will be combined and returned to end user as one result set.


In the upcoming sections the system architecture will be viewed from different perspectives at a high level
of abstraction that allows us to visualize, understand and reason about the architecturally significant
elements and identify areas of risk that require more detailed elaboration.


The architecture of the reference application is represented following the recommendations of the Rational
Unified Process (RUP). The system specifications have been divided into the following five views:


<b>Use-Case View</b>: Describes the actors and use cases for the system, this view presents the needs of
the user and is elaborated further at the design level to describe discrete flows and constraints in
more detail.


<b>Logical View</b>: This view describes the architecturally significant parts of the design model, such
as its decomposition into subsystems and packages. And for each significant package, its
decomposition into classes and class utilities. We will introduce architecturally significant classes
and describe their responsibilities, as well as important relationships, operations, and attributes.


<b>Deployment View</b>: Describes the deployment structures, by including known deployment
methods. It will also describe the physical network (hardware) configurations on which the


software is deployed and run. In this configuration we will indicate the physical nodes that
execute the software, and their interconnections


<b>Implementation View</b>: This view describes the overall structure of the implementation model, the
decomposition of the software into layers and subsystems in the implementation model, and all
architecturally significant components.


<b>3. </b>

<b>Architectural Goals and Constraints </b>



Search Service application is based on a Service Oriented Architecture (SOA). SOA is an architectural
style whose goal is to achieve loose coupling among interacting software agents. A service is a unit of work
done by a service provider to achieve desired end results for a service consumer. In our case this service
will be provided by Google and Amazon web services. More over the mentioned web services will feed our
composition web service.


<b>3.1 </b> <b>Google Web Service Constraints </b>


To access the Google web service, we should have a license key. This key will be available after registering
to Google web service. In each query this license key should be included. Google web service uses this
license key to control and limit the access to its services. The Google Web APIs service is an experimental
free program, so the resources available to support the program are limited. Since the Google web service is
a free beta service, it cannot be guaranteed that every question will be answered by Google team. Also
based on the Google Web APIs terms of service we cannot create a commercial service using Google Web
APIs without first obtaining written consent from Google. Another is that you can only create one account
for your personal use.


</div>
<span class='text_page_counter'>(6)</span><div class='page_container' data-page=6>

TU-Wien, 2005 Page 6 of 14
<b>3.2 </b> <b>Amazon Web Service Constraints </b>


Amazon will identify the end users like Google using a subscription ID. A subscription ID is a unique


identifier connected to Amazon Web Service (AWS). The subscription ID is needed to access any of the
web services offered by AWS. Comparing to Google, Amazon has provided a more commercial-oriented
web service. Amazon Web Services provides a platform that developers can use to create software that
enhances the productivity of Amazon merchants, Associates, or Web site owners, and increases value to
customers.


<b>3.3 </b> <b>Standards and used technologies </b>


The Search Service should use a set of standard technologies for implementation. These standards are those
that are based on Java technologies as well as the some related open source applications. The employed
technologies are as follows:


<b>Java J2SE 1.4.2</b>: Java 2 Standard edition which provides a complete environment for applications
development on desktops and servers.


<b>Apache Axis</b>: Apache Axis is an implementation of the SOAP (Simple Object Access Protocol).
SOAP is a lightweight protocol for exchange of information in a decentralized, distributed
environment. It is an XML based protocol that consists of three parts: an envelope that defines a
framework for describing what is in a message and how to process it, a set of encoding rules for
expressing instances of application-defined data types, and a convention for representing remote
procedure calls and responses.


<b>JBoss 3.2.6</b>: JBoss should be used as Search Service application server. The JBoss/Server is the
leading Open Source, standards-compliant, J2EE based application server implemented in 100%
Pure Java. JBoss Application Server has become a recognized leader in the Java application server
market and is to date the only major application server on the market to deliver a production-ready
J2EE 1.4 certified product. JBoss Application Server has quickly become the most popular
product among Java developers and independent software vendors alike. According to some
independent benchmark tests, JBoss offers improved performance and superior server utilization
to other leading J2EE application servers.



<b>Apache Ant</b>: Apache Ant will be used as build and deployment tool. Apache Ant is a Java-based
build tool. In theory, it is kind of like Make, but without Make's wrinkles; i.e. Instead of a model
where it is extended with shell-based commands, Ant is extended using Java classes. Instead of
writing shell commands, the configuration files are XML-based, calling out a target tree where
various tasks get executed. Each task is run by an object that implements a particular Task
interface.


<b>Eclipse</b>: Eclipse is a kind of universal tool platform - an open extensible IDE for anything and
nothing in particular. It will be used as development tool.


</div>
<span class='text_page_counter'>(7)</span><div class='page_container' data-page=7>

TU-Wien, 2005 Page 7 of 14

<b>4. </b>

<b>Use-Case View </b>



This view presents the users perception of the functionality provided by Search Service. These use cases
were included in the exercise specifications and hopefully captures all requested features.


Note that this section provides the context for, and scope of the rest of the document. Putting aside
overriding architectural constraints outlined above all development (in terms of design and content
documentation) has been done in support of one or more of the following use cases.


<b>4.1 </b> <b>Use-Case Realizations </b>


The system will have three major use cases. Tow simple web service clients for accessing Google and
Amazon web services. Also there will be a composition web service, which send a query to Google and
Amazon web services and combines the results.


<i>4.1.1 Google Search Use case </i>


In this use case the end user who is considered as use case actor will ask the system to send a query to


Google. The system will call Google web service and displays the results in a customized format.


<i>4.1.2 Amazon Search Use case </i>


This use case is similar to Google web service, but the query is sent to Amazon web service instead. The
results could be shown in a customized way to the end user.


<i>4.1.3 Combined Search Use case </i>


</div>
<span class='text_page_counter'>(8)</span><div class='page_container' data-page=8>

TU-Wien, 2005 Page 8 of 14

<b>5. </b>

<b>Logical View </b>



This section describes the architecturally significant elements of the search system. The system is
decomposed into some sub-system, to realize the requirements of the above mentioned use cases.


<b>5.1 </b> <b>Overview </b>


The design model is a client server model. Part of the system is automatically generated from the Web
Service Description Language files (WSDL files). These generated files are organized into two packages,
one for Google web service and the other one for Amazon web service. The package names are
“googleSearch” and “amazonSearch” respectively. For each web service another package exists which will
play the role of web service client; these packages are called google and amazon.


</div>
<span class='text_page_counter'>(9)</span><div class='page_container' data-page=9>

TU-Wien, 2005 Page 9 of 14
<b>5.2 </b> <b>Architecturally Significant Design Packages </b>


In this section we will describe the details of significant packages including the description of important
classes.


<i>5.2.1 Amazon Package </i>



</div>
<span class='text_page_counter'>(10)</span><div class='page_container' data-page=10>

TU-Wien, 2005 Page 10 of 14


<i>5.2.2 Google Package </i>


This package includes a java class called “GoogleClient” which serves as client for Google web service and
also provide a method that is called from search session bean. The main method of this class is used for a
simple call to Google web service. The class has also another method for serialization of results which are
query items. Basically it is possible to let the end user to create his/her favorite serialization methods by
overwriting the “serializeSearchItem” method; however we have decided to implement this method as a
private method which can not be overwritten.


<i>5.2.3 Server Package </i>


This package includes the necessary file for our stateless session bean which serves the combined web
service. The following diagram shows all the classes included in this package:


SearchPoint
<<EJBRemoteMethod>> runQuery()
<i>SearchPointBean</i>
SearchPointBean()
runQuery()
SearchPointLocal
SearchPointSession
SearchPointSession()
ejbActivate()
ejbPassivate()
setSessionContext()
<<EJBRemoteMethod>> unsetSessionContext()
ejbRemove()


<<EJBCreateMethod>> ejbCreate()
SearchPointHome


COMP_NAME : String
JNDI_NAME : String
<<EJBCreateMethod>> create()
SearchPointLocalHome


COMP_NAME : String
JNDI_NAME : String
<<EJBCreateMethod>> create()


SearchPointUtil
hexServerIP : String
SearchPointUtil()
lookupHome()
getHome()
getHome()
getLocalHome()
generateGUID()
getInt()
hexFormat()
padHex()
-$cachedRemoteHome
-$cachedLocalHome


</div>
<span class='text_page_counter'>(11)</span><div class='page_container' data-page=11>

TU-Wien, 2005 Page 11 of 14


:



SearchPointBean GoogleClientgoogle : AmazonClientamazon :
query(String)


bookQuery(String)


<b>6. </b>

<b>Deployment View </b>



The system is composed of server side and client side components. The client computer will have only a
simple EJB client component. On the Search Point Server the server side components will be deployed.
This server has JBoss server plus Axis for serving our web service. This server should have access to
Google and Amazon servers for performing queries.


Client SearchPoint<sub>Server</sub>


Google
Server


Amazon
Server


</div>
<span class='text_page_counter'>(12)</span><div class='page_container' data-page=12>

TU-Wien, 2005 Page 12 of 14
<?xml version="1.0" ?>


<deployment xmlns='
xmlns:java='
xmlns:soap='
xmlns:xsi='
xmlns:xsd='


<service name="SearchPoint" provider="java:EJB">



<parameter name="beanJndiName" value="SearchPointEjb"/>


<parameter name="homeInterfaceName" value="org.amin.server.SearchPointHome"/>
<parameter name="remoteInterfaceName" value="org.amin.server.SearchPoint"/>
<parameter name="allowedMethods" value="runQuery"/>


</service>
</deployment>


The deployment descriptor is called via execution of an Ant script and more explicitly by calling the
following target:


<!-- Deploy Webservice -->


<target name="setup-axispoint" description="Deploy Webservice">
<java classname="org.apache.axis.client.AdminClient" fork="yes">


<classpath refid="master-classpath"/>
<arg value="./wsdl/deploy.wsdd"/>
</java>


</target>


Another important target in Ant file is the EJB deployment target which deploys the created EJB file to
JBoss server.


Also all client applications are accessible via Ant script. To run them on client side only Java run time
environment plus Apache Ant is needed.



<b>7. </b>

<b>Implementation View </b>



</div>
<span class='text_page_counter'>(13)</span><div class='page_container' data-page=13>

TU-Wien, 2005 Page 13 of 14
JBoss 3.2.x provides a bundled Web services implementation. This bundled service is called JBoss.NET
and incorporates Axis as a plug-in service for the JBoss microkernel. Deployment of Web services uses the
built-in JBoss deployment system that understands the WSR (Web Service aRchive) packaging.


Axis is an implementation of the Simple Object Access Protocol (SOAP). SOAP is a lightweight protocol
for exchange of information in a decentralized, distributed environment and the protocol is XML-based.
The protocol consists of three parts: an envelope that defines a framework for describing what is in a
message and how to process it, a set of encoding rules for expressing instances of application-defined data
types, and a convention for representing remote procedure calls and responses. Axis can convert an EJB
into a Web service by providing the interface plumbing and the service delivery. The following shows the
components from implementation point of view:


SearchPoint
Combined Web


Service


<<Application>>


Google
Library


Amazon
Library


<b>8. </b>

<b>Size and Performance </b>




Web Services applications have the primary goal of sharing and using data between applications. The
Combined search service which send two simple queries and manages a small amount of data will respond
to the requests in time. However some big technical and performance issues for Web services occurs when
a user or application is handling large data or binary files.


W3C's XML Protocol Working Group has been looking at this issue almost from its inception, while it was
developing the first SOAP standard, SOAP 1.2. The newest Recommendations published today work with
SOAP 1.2 to address the specific issue of improving Web services performance by providing standard
methods and mechanisms for transmitting large or binary data.


<b>9. </b>

<b>Quality </b>



</div>
<span class='text_page_counter'>(14)</span><div class='page_container' data-page=14>

TU-Wien, 2005 Page 14 of 14
<b>9.1 </b> <b>Performance </b>


From the performance point of view the system should be able to respond in a reasonable time. However
evaluating the performance of web service oriented systems is not as easy as traditional architectures.
While Web services ease the building of client-server systems, monitoring service quality is a significant
problem. Consider a client application that submits a transaction on our web service. Our business
transaction involves two Web service calls to Google and Amazon web services. Each call is a distinct
HTTP/SOAP (Simple Object Access Protocol) exchange and the performance of our web service would be
greatly affected by depending web services. Fortunately in our case the underneath web services look to be
stable enough and answering the queries in time.




<b>9.2 </b> <b>Security </b>


Web service security is an important issue in implementation of web services and there are well-known
methods which apply security policies to web services. In our case the security is not our primary concern


since we do a simple query. Should the system be extended to support e-commerce issues for Amazon web
service, the security issues come to play.


<b>9.3 </b> <b>Portability </b>


Portability issues are about abstracting the interfaces that a business application uses to communicate with
the underlying system upon which it is running. The web service oriented architecture has loosely coupled
components which are simply portable to other systems. Also the client application could be web based or
written in any favorite language. The current java client portability is very high, since the only requirement
to run the client is java enabled environment and fortunately the JVM is available for nearly all well known
operating systems.


<b>9.4 </b> <b>Reusability </b>


</div>

<!--links-->

Tài liệu bạn tìm kiếm đã sẵn sàng tải về

Tải bản đầy đủ ngay
×