SOP Module 2 Slides - Computer Networks Lab

advertisement
Course Module 2:
Service-Oriented Programming
(SOP)
SOP as a Programming Paradigm
in a
Middle-Level Undergraduate Course
SOP Course Module 2
Slide 1
Acknowledgments
• This material is based upon work supported
by the National Science Foundation under
Awards No. DUE-1140567, DUE-1141112, and
DUE-1141200. Any opinions, findings, and
conclusions or recommendations expressed in
this material are those of the authors and do
not necessarily reflect the views of the
National Science Foundation.
SOP Course Module 2
Slide 2
Module Learning Outcomes
• Students will be able to:
– Describe the role and importance of service-oriented
programming in current application development
– Explain the basic concepts of web services and
service-oriented architecture
– Explain the standards underlying service-oriented
architecture and web services
– Build and use web services using C# or Java
– Explain how software reuse and quality are improved
by the use of web services’ composition
SOP Course Module 2
Slide 3
Common Programming Paradigms
• Imperative paradigm
– Based on von Neumann architecture where computation combines
logic (what is to be done) and control flow (how it is to be done)
• Functional paradigm
– All computations are done by defining and applying (calling)
mathematical functions
• Logic paradigm
– Computation is a systematic attempt to satisfy a goal based on
provided facts and inference rules
• Object-oriented paradigm
– Objects represent state and behavior, and computation is
accomplished by messages sent among objects
– Objects created from classes and inheritance provide software reuse
SOP Course Module 2
Slide 4
SOP: Another Programming Paradigm
• SOP is a new programming paradigm
• Uses “services” as the unit of work to design
and develop integrated business applications
and mission critical software programs
• Inherently designed to reuse existing services
• Naturally supports software reuse, which in
turn helps to improve software quality
SOP Course Module 2
Slide 5
Object- and Service-Orientation
• Steps in solving a complex problem
– Abstraction
• Decomposes problem into sub-problems
• Solves each sub-problem and compose the overall solution
– Object-orientation
• Describes an abstraction using objects
• Objects help to model problem and develop the solution
– Service-orientation
• Describes an abstraction using services
• Services help to model problem and develop the solution
• Developed service can be used to develop new services
SOP Course Module 2
Slide 6
Programming Abstractions: Evolution
– Figure is from Introduction to Web Services by Dr.
Marcello La Rosa, QUT
SOP Course Module 2
Slide 7
Service-Oriented Programming (SOP)
• SOP
– A programming paradigm that uses “services” as the
building block to develop applications
• Approach
– Develop services
– Make use of services by invoking (calling) others
– Combine services to make additional services
• Main ideas
– Make use of web services
– Should be easy to make use of web services
SOP Course Module 2
Slide 8
What is a Web Service?
• A service (high-level description)
– Similar to a method
– A program calls a method and gets some results back
• A web service (high-level description)
– A service that can be invoked by a program over the
web (http)
• A web service is different from a web application
– A web application is for use by humans
• Such as http://www.weather.com
– A web service is for use by programs
• Such as Twitter APIs https://dev.twitter.com/docs/api/1
SOP Course Module 2
Slide 9
Web Service: Definition
• From W3C (World Wide Web Consortium)
– It is a software system designed to support interoperable
machine-to-machine interaction over a network
– Its interface is described in a machine-processable format
(specifically WSDL)
– Other systems interact with the Web service as specified
by its description using SOAP messages, typically over
HTTP with an XML serialization along with other webrelated standards
WSDL: Web Service Description Language
SOAP: Simple Object Access Protocol
SOP Course Module 2
Slide 10
Web Services: Features and Standards
• Global accessibility via the web
– Leverages web’s powerful communication paradigm
– Accessible via HTTP (across firewalls)
• Standardization, XML-based
–
–
–
–
WSDL: used for service description (www.w3.org/TR/wsdl)
UDDI: for service publishing and discovery (uddi.xml.org/)
SOAP: for service invocation (www.w3.org/TR/SOAP/)
Others
WSDL: Web Service Description Language
UDDI: Universal Description, Discovery and Integration
SOAP: Simple Object Access Protocol
SOP Course Module 2
Slide 11
Examples of Web Services
• A self-contained business task
– A money withdrawal or funds deposit service for a bank
• A full-fledged business process with multiple tasks
– Automated purchasing of office supplies with approvals at
different levels
• An application
– A complete life insurance application
• A service-enabled resource
– Access to a remote database containing patient medical
records
SOP Course Module 2
self-contained: does not need other resources
business task: simple logical step 12
Slide 12
What Web Services Bring to SOP
• OOP typically constrained to homogeneity
– Same data types, programming languages,
development platform, operating systems
• Web services handle heterogeneity
– Extensive use of XML as it has become ubiquitous
– Deal with the accessibility by providing access to
functionalities available on the web (standard
networking and http)
• SOP
– Builds on web services to support software reuse
SOP Course Module 2
Slide 13
Accessing Functionality
• Traditional software development
– Download functionality in a code library and link new
code to use it
• SOP software development
– Access to functionalities already on the web
• Use existing networking infrastructure
• HTTP has become ubiquitous
• OOP software development
– Can also use functionality but needs some access
mechanisms to identify functionality
SOP Course Module 2
Slide 14
SOP: A New Problem Solving Paradigm
• Traditional software development
– Develop a new app from scratch
• SOP
– Develop a new app not from scratch but by using
existing services
• Decompose problem into sub-problems
• For each sub-problem, select existing or develop
appropriate services
• Combine these services together to create new app
SOP Course Module 2
Slide 15
SOP At Present
• Major companies support web services
– Microsoft, IBM, HP, Oracle, BEA, SAP, and others
– Deliver their functionalities as web services
• Many web services available published online
– Over 11,101 web services and 7,364 mashups (SOP apps)
• http://www.programmableWeb.com
– Other search engines for web services
• http://www.webservicelist.com
• http://www.biocatalogue.org (curated catalog for life sciences)
• Web transformation
– From an information repository to a service repository
SOP Course Module 2
Slide 16
Web Services: Commercial
Frameworks
• Microsoft (Windows Communication Foundation)
– http://msdn.microsoft.com/enus/library/dd456779.aspx
• IBM (“simply good design”)
– http://www-01.ibm.com/software/solutions/soa/
• Oracle (“agile and reusable connectivity”)
– http://www.oracle.com/us/products/middleware/soa
/overview/index.html
• Hewlett Packard
– http://h71028.www7.hp.com/enterprise/w1/en/tech
nologies/soa-overview.html
SOP Course Module 2
Slide 17
SOP: An Example Application
• Develop a web-based query application to
allow users view gas stations, local weather
and driving information at a given location
• Input
– address
• Output
– List of gas stations
– Local weather
– Driving directions
SOP Course Module 2
Slide 18
SOP: Designing the Application
• Traditional design
approach
– Develop a gas station
service
• Input: address
• Output: gas stations nearby
– Develop a weather service
• Input: address
• Output: local weather
– Develop a route service
• Not trivial to develop any
of these services
• SOP approach
– First see if existing web
services can handle one or
more of the above
– Use those functionalities
via existing web services
– Build the rest
• Input: two addresses
• Output: Driving directions
SOP Course Module 2
Slide 19
The Three APIs
• For hotel service: use Expedia APIs
– http://developer.ean.com/docs/hotels/
– Demo: http://vhost3.cs.rit.edu/Application/
• For weather service: use Weather underground API
– http://www.wunderground.com/weather/api/d/docs
– (weather, humidity, temperature, wind speed, etc.)
– Demo: http://vhost3.cs.rit.edu/Application/
• For location service: use Google Directions API
– https://developers.google.com/maps/documentation/dire
ctions/
– Demo: http://vhost3.cs.rit.edu/Application/
SOP Course Module 2
Slide 20
SOP Basis: Service-Oriented
Architecture (SOA)
Service
Registry
Web Browser
0.0000
UDDI Registry
Publish
UDDI Publication
Find
UDDI Inquiry
Service
Consumer
message
Web Service
0.0000
defines
has
exchange
Service
Provider
0.0000
Web Service
SOP Course Module 2
SOAP
Service Description
WSDL
Slide 21
Download